Geant4  9.6.p02
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
G4ErrorSurfaceTrajParam.cc
Go to the documentation of this file.
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 // $Id: G4ErrorSurfaceTrajParam.cc 69766 2013-05-14 14:33:55Z gcosmo $
27 //
28 // ------------------------------------------------------------
29 // GEANT 4 class implementation file
30 // ------------------------------------------------------------
31 //
32 
34 #include <iomanip>
35 
36 #include "G4ThreeVector.hh"
37 #include "G4GeometryTolerance.hh"
38 
39 //------------------------------------------------------------------------
42  const G4Vector3D& vecV, const G4Vector3D& vecW )
43 {
44  SetParameters( pos, mom, vecV, vecW );
45 }
46 
47 
48 //------------------------------------------------------------------------
51  const G4Plane3D& plane )
52 {
53  SetParameters( pos, mom, plane );
54 }
55 
56 //------------------------------------------------------------------------
58 SetParameters( const G4Point3D& pos, const G4Vector3D& mom,
59  const G4Plane3D& plane )
60 {
61  //--- Get two perpendicular vectors: first parallel X
62  // (unless normal is parallel to X, then take Y)
63 
64  G4double kCarTolerance =
66 
67  G4ThreeVector Xvec(1.,0.,0.);
68  G4Vector3D vecV = -Xvec.cross(plane.normal());
69  if( vecV.mag() < kCarTolerance )
70  {
71  G4ThreeVector Zvec(0.,0.,1.);
72  vecV = Zvec.cross(plane.normal());
73  }
74 
75  G4Vector3D vecW = plane.normal().cross( vecV );
76 
77  SetParameters( pos, mom, vecV, vecW );
78 }
79 
80 
81 //------------------------------------------------------------------------
83 SetParameters( const G4Point3D& pos, const G4Vector3D& mom,
84  const G4Vector3D& vecV, const G4Vector3D& vecW )
85 {
86  if( mom.mag() > 0. ) {
87  fDir = mom;
88  fDir /= mom.mag();
89  } else {
90  fDir = G4Vector3D(0.,0.,0.);
91  }
92  fVectorV = vecV / vecV.mag();
93  fVectorW = vecW / vecW.mag();
94  fInvP = 1./mom.mag();
95  G4ThreeVector momv(mom);
96  //check 3 vectors are ortogonal and right handed
97 
98  // now all 4 scalar memeber variables retain the signs
99  // fPV = momv.project( vecV ).mag();
100  // fPW = momv.project( vecW ).mag();
101  fPV = momv.dot( vecV );
102  fPW = momv.dot( vecW );
103 
104 
105  G4ThreeVector posv(pos);
106  // fV = posv.project( vecV ).mag();
107  // fW = posv.project( vecW ).mag();
108  fV = posv.dot( vecV );
109  fW = posv.dot( vecW );
110 }
111 
112 
113 //------------------------------------------------------------------------
114 std::ostream& operator<<(std::ostream& out, const G4ErrorSurfaceTrajParam& tp)
115 {
116  // long mode = out.setf(std::ios::fixed,std::ios::floatfield);
117 
118  // out << tp.theType;
119  // out << std::setprecision(5) << std::setw(10);
120  out << " InvP= " << tp.fInvP << " PV= " << tp.fPV
121  << " PW= " << tp.fPW << " V= " << tp.fV << " W= " << tp.fW << G4endl;
122  out << " vectorV direction= " << tp.fVectorV
123  << " vectorW direction= " << tp.fVectorW << G4endl;
124 
125  return out;
126 }