ECCE @ EIC Software
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4ErrorPropagationNavigator.hh
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file G4ErrorPropagationNavigator.hh
1 //
2 // ********************************************************************
3 // * License and Disclaimer *
4 // * *
5 // * The Geant4 software is copyright of the Copyright Holders of *
6 // * the Geant4 Collaboration. It is provided under the terms and *
7 // * conditions of the Geant4 Software License, included in the file *
8 // * LICENSE and available at http://cern.ch/geant4/license . These *
9 // * include a list of copyright holders. *
10 // * *
11 // * Neither the authors of this software system, nor their employing *
12 // * institutes,nor the agencies providing financial support for this *
13 // * work make any representation or warranty, express or implied, *
14 // * regarding this software system or assume any liability for its *
15 // * use. Please see the license in the file LICENSE and URL above *
16 // * for the full disclaimer and the limitation of liability. *
17 // * *
18 // * This code implementation is the result of the scientific and *
19 // * technical work of the GEANT4 collaboration. *
20 // * By using, copying, modifying or distributing the software (or *
21 // * any work based on the software) you agree to acknowledge its *
22 // * use in resulting scientific publications, and indicate your *
23 // * acceptance of all terms of the Geant4 Software license. *
24 // ********************************************************************
25 //
26 // class G4ErrorPropagationNavigator
27 //
28 // Class Description:
29 //
30 // Class for performing double navigation in the detector geometry and
31 // on the target surface for error propagation. It overloads ComputeStep()
32 // and ComputeSafety() methods.
33 
34 // History:
35 // - Created. P. Arce, September 2004
36 // --------------------------------------------------------------------
37 
38 #ifndef G4ErrorPropagationNavigator_hh
39 #define G4ErrorPropagationNavigator_hh
40 
41 #include "G4Navigator.hh"
42 #include "G4ThreeVector.hh"
43 
45 {
46  public: // with description
47 
50 
51  G4double ComputeStep (const G4ThreeVector &pGlobalPoint,
52  const G4ThreeVector &pDirection,
53  const G4double pCurrentProposedStepLength,
54  G4double &pNewSafety);
55  // Calls the navigation in the detector geometry and then checks
56  // if the distance to surface is smaller than the proposed step
57 
58  G4double ComputeSafety(const G4ThreeVector &globalpoint,
59  const G4double pProposedMaxLength = DBL_MAX,
60  const G4bool keepState = true);
61  // Calls the navigation in the detector geometry and then checks
62  // if the distance to surface is smaller than the proposed safety
63 
65  G4bool* valid);
66  // Return Exit Surface Normal and validity too. Can only be called if
67  // the Navigator's last Step has crossed a volume geometrical boundary.
68  // Normal points out of the volume exited and/or into the volume entered.
69 
70  G4double TargetSafetyFromPoint( const G4ThreeVector &pGlobalpoint );
71  // Isotropic safety for 'Target'
72 
73  //-- NOT implemented, as it is difficult to define the coordinate system:
74  // G4ThreeVector GetLocalExitNormal(G4bool* valid);
75  // G4ThreeVector GetLocalExitNormalAndCheck(const G4ThreeVector& point,
76  // G4bool* valid);
77  // Convention:
78  // The *local* normal is in the coordinate system of the *final* volume.
79 };
80 
81 #endif