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 // 26 // >> 27 // $Id: G4Polyhedron.cc,v 1.20 2006/06/29 19:07:04 gunter Exp $ >> 28 // GEANT4 tag $Name: geant4-08-02 $ 27 29 28 #include "G4Polyhedron.hh" 30 #include "G4Polyhedron.hh" 29 31 30 G4Polyhedron::G4Polyhedron () << 32 G4Polyhedron::G4Polyhedron (): 31 = default; << 33 fNumberOfRotationStepsAtTimeOfCreation (fNumberOfRotationSteps) 32 << 33 G4Polyhedron::G4Polyhedron (G4int Nvert, G4int << 34 HepPolyhedron (Nvert, Nface) << 35 {} 34 {} 36 35 37 G4Polyhedron::~G4Polyhedron () = default; << 36 G4Polyhedron::~G4Polyhedron () {} 38 37 39 G4Polyhedron::G4Polyhedron (const HepPolyhedro 38 G4Polyhedron::G4Polyhedron (const HepPolyhedron& from) 40 : HepPolyhedron(from) 39 : HepPolyhedron(from) 41 { 40 { 42 fNumberOfRotationStepsAtTimeOfCreation = 41 fNumberOfRotationStepsAtTimeOfCreation = 43 from.fNumberOfRotationSteps; 42 from.fNumberOfRotationSteps; 44 } 43 } 45 44 46 G4PolyhedronBox::G4PolyhedronBox (G4double dx, 45 G4PolyhedronBox::G4PolyhedronBox (G4double dx, G4double dy, G4double dz): 47 G4Polyhedron (HepPolyhedronBox (dx, dy, dz)) 46 G4Polyhedron (HepPolyhedronBox (dx, dy, dz)) {} 48 47 49 G4PolyhedronBox::~G4PolyhedronBox () = default << 48 G4PolyhedronBox::~G4PolyhedronBox () {} 50 49 51 G4PolyhedronCone::G4PolyhedronCone (G4double R << 50 G4PolyhedronCone::G4PolyhedronCone (G4double Rmn1, G4double Rmx1, 52 G4double R << 51 G4double Rmn2, G4double Rmx2, G4double Dz): 53 G4Polyhedron (HepPolyhedronCone (Rmn1, Rmx1, 52 G4Polyhedron (HepPolyhedronCone (Rmn1, Rmx1, Rmn2, Rmx2, Dz)) {} 54 53 55 G4PolyhedronCone::~G4PolyhedronCone () = defau << 54 G4PolyhedronCone::~G4PolyhedronCone () {} 56 55 57 G4PolyhedronCons::G4PolyhedronCons (G4double R << 56 G4PolyhedronCons::G4PolyhedronCons (G4double Rmn1, G4double Rmx1, 58 G4double R << 57 G4double Rmn2, G4double Rmx2, G4double Dz, 59 G4double P << 58 G4double Phi1, G4double Dphi): 60 G4Polyhedron (HepPolyhedronCons (Rmn1, Rmx1, 59 G4Polyhedron (HepPolyhedronCons (Rmn1, Rmx1, Rmn2, Rmx2, Dz, Phi1, Dphi)) {} 61 60 62 G4PolyhedronCons::~G4PolyhedronCons () = defau << 61 G4PolyhedronCons::~G4PolyhedronCons () {} 63 62 64 G4PolyhedronPara::G4PolyhedronPara (G4double D 63 G4PolyhedronPara::G4PolyhedronPara (G4double Dx, G4double Dy, G4double Dz, 65 G4double A << 64 G4double Alpha, G4double Theta, 66 G4double P << 65 G4double Phi): 67 G4Polyhedron (HepPolyhedronPara (Dx, Dy, Dz, 66 G4Polyhedron (HepPolyhedronPara (Dx, Dy, Dz, Alpha, Theta, Phi)) {} 68 67 69 G4PolyhedronPara::~G4PolyhedronPara () = defau << 68 G4PolyhedronPara::~G4PolyhedronPara () {} 70 69 71 G4PolyhedronPcon::G4PolyhedronPcon (G4double p 70 G4PolyhedronPcon::G4PolyhedronPcon (G4double phi, G4double dphi, G4int nz, 72 const G4do << 71 const G4double *z, 73 const G4do << 72 const G4double *rmin, 74 const G4do << 73 const G4double *rmax): 75 G4Polyhedron (HepPolyhedronPcon (phi, dphi, 74 G4Polyhedron (HepPolyhedronPcon (phi, dphi, nz, z, rmin, rmax)) {} 76 75 77 G4PolyhedronPcon::G4PolyhedronPcon (G4double p << 76 G4PolyhedronPcon::~G4PolyhedronPcon () {} 78 const std: << 79 G4Polyhedron (HepPolyhedronPcon(phi, dphi, r << 80 << 81 G4PolyhedronPcon::~G4PolyhedronPcon () = defau << 82 77 83 G4PolyhedronPgon::G4PolyhedronPgon (G4double p 78 G4PolyhedronPgon::G4PolyhedronPgon (G4double phi, G4double dphi, G4int npdv, 84 G4int nz, << 79 G4int nz, 85 const G4do << 80 const G4double *z, 86 const G4do << 81 const G4double *rmin, 87 const G4do << 82 const G4double *rmax): 88 G4Polyhedron (HepPolyhedronPgon (phi, dphi, 83 G4Polyhedron (HepPolyhedronPgon (phi, dphi, npdv, nz, z, rmin, rmax)) {} 89 84 90 G4PolyhedronPgon::G4PolyhedronPgon (G4double p << 85 G4PolyhedronPgon::~G4PolyhedronPgon () {} 91 const std: << 92 G4Polyhedron (HepPolyhedronPgon(phi, dphi, n << 93 << 94 G4PolyhedronPgon::~G4PolyhedronPgon () = defau << 95 86 96 G4PolyhedronSphere::G4PolyhedronSphere (G4doub 87 G4PolyhedronSphere::G4PolyhedronSphere (G4double rmin, G4double rmax, 97 G4doub << 88 G4double phi, G4double dphi, 98 G4doub << 89 G4double the, G4double dthe): 99 G4Polyhedron (HepPolyhedronSphere (rmin, rma 90 G4Polyhedron (HepPolyhedronSphere (rmin, rmax, phi, dphi, the, dthe)) {} 100 91 101 G4PolyhedronSphere::~G4PolyhedronSphere () = d << 92 G4PolyhedronSphere::~G4PolyhedronSphere () {} 102 << 103 G4PolyhedronTet::G4PolyhedronTet (const G4doub << 104 const G4doub << 105 const G4doub << 106 const G4doub << 107 G4Polyhedron (HepPolyhedronTet (p0, p1, p2, << 108 << 109 G4PolyhedronTet::~G4PolyhedronTet () = default << 110 93 111 G4PolyhedronTorus::G4PolyhedronTorus (G4double 94 G4PolyhedronTorus::G4PolyhedronTorus (G4double rmin, G4double rmax, 112 G4double << 95 G4double rtor, 113 G4double << 96 G4double phi, G4double dphi): 114 G4Polyhedron (HepPolyhedronTorus (rmin, rmax 97 G4Polyhedron (HepPolyhedronTorus (rmin, rmax, rtor, phi, dphi)) {} 115 98 116 G4PolyhedronTorus::~G4PolyhedronTorus () = def << 99 G4PolyhedronTorus::~G4PolyhedronTorus () {} 117 100 118 G4PolyhedronTrap::G4PolyhedronTrap (G4double D 101 G4PolyhedronTrap::G4PolyhedronTrap (G4double Dz, G4double Theta, G4double Phi, 119 G4double D << 102 G4double Dy1, 120 G4double D << 103 G4double Dx1, G4double Dx2, G4double Alp1, 121 G4double D << 104 G4double Dy2, 122 G4double D << 105 G4double Dx3, G4double Dx4, G4double Alp2): 123 G4Polyhedron (HepPolyhedronTrap (Dz, Theta, 106 G4Polyhedron (HepPolyhedronTrap (Dz, Theta, Phi, Dy1, Dx1, Dx2, Alp1, 124 Dy2, Dx3, D << 107 Dy2, Dx3, Dx4, Alp2)) {} 125 108 126 G4PolyhedronTrap::~G4PolyhedronTrap () = defau << 109 G4PolyhedronTrap::~G4PolyhedronTrap () {} 127 110 128 G4PolyhedronTrd1::G4PolyhedronTrd1 (G4double D 111 G4PolyhedronTrd1::G4PolyhedronTrd1 (G4double Dx1, G4double Dx2, 129 G4double D << 112 G4double Dy, G4double Dz): 130 G4Polyhedron (HepPolyhedronTrd1 (Dx1, Dx2, D 113 G4Polyhedron (HepPolyhedronTrd1 (Dx1, Dx2, Dy, Dz)) {} 131 114 132 G4PolyhedronTrd1::~G4PolyhedronTrd1 () = defau << 115 G4PolyhedronTrd1::~G4PolyhedronTrd1 () {} 133 116 134 G4PolyhedronTrd2::G4PolyhedronTrd2 (G4double D 117 G4PolyhedronTrd2::G4PolyhedronTrd2 (G4double Dx1, G4double Dx2, 135 G4double D << 118 G4double Dy1, G4double Dy2, G4double Dz): 136 G4Polyhedron (HepPolyhedronTrd2 (Dx1, Dx2, D 119 G4Polyhedron (HepPolyhedronTrd2 (Dx1, Dx2, Dy1, Dy2, Dz)) {} 137 120 138 G4PolyhedronTrd2::~G4PolyhedronTrd2 () = defau << 121 G4PolyhedronTrd2::~G4PolyhedronTrd2 () {} 139 122 140 G4PolyhedronTube::G4PolyhedronTube (G4double R 123 G4PolyhedronTube::G4PolyhedronTube (G4double Rmin, G4double Rmax, G4double Dz): 141 G4Polyhedron (HepPolyhedronTube (Rmin, Rmax, 124 G4Polyhedron (HepPolyhedronTube (Rmin, Rmax, Dz)) {} 142 125 143 G4PolyhedronTube::~G4PolyhedronTube () = defau << 126 G4PolyhedronTube::~G4PolyhedronTube () {} 144 127 145 G4PolyhedronTubs::G4PolyhedronTubs (G4double R << 128 G4PolyhedronTubs::G4PolyhedronTubs (G4double Rmin, G4double Rmax, G4double Dz, 146 G4double P << 129 G4double Phi1, G4double Dphi): 147 G4Polyhedron (HepPolyhedronTubs (Rmin, Rmax, 130 G4Polyhedron (HepPolyhedronTubs (Rmin, Rmax, Dz, Phi1, Dphi)) {} 148 131 149 G4PolyhedronTubs::~G4PolyhedronTubs () = defau << 132 G4PolyhedronTubs::~G4PolyhedronTubs () {} 150 << 151 G4PolyhedronParaboloid::G4PolyhedronParaboloid << 152 << 153 << 154 G4Polyhedron (HepPolyhedronParaboloid(r1, r2 << 155 << 156 G4PolyhedronParaboloid::~G4PolyhedronParaboloi << 157 << 158 G4PolyhedronHype::G4PolyhedronHype (G4double r << 159 G4double t << 160 G4Polyhedron (HepPolyhedronHype(r1, r2, tan1 << 161 << 162 G4PolyhedronHype::~G4PolyhedronHype () = defau << 163 133 164 G4PolyhedronEllipsoid::G4PolyhedronEllipsoid ( 134 G4PolyhedronEllipsoid::G4PolyhedronEllipsoid (G4double ax, G4double by, 165 << 135 G4double cz, 166 << 136 G4double zCut1, G4double zCut2): 167 G4Polyhedron (HepPolyhedronEllipsoid (ax, by 137 G4Polyhedron (HepPolyhedronEllipsoid (ax, by, cz, zCut1, zCut2)) {} 168 138 169 G4PolyhedronEllipsoid::~G4PolyhedronEllipsoid << 139 G4PolyhedronEllipsoid::~G4PolyhedronEllipsoid () {} 170 140 171 G4PolyhedronEllipticalCone::G4PolyhedronEllipt << 141 G4PolyhedronEllipticalCone::G4PolyhedronEllipticalCone (G4double ax, G4double ay, 172 << 142 G4double h, 173 << 143 G4double zCut1): 174 << 175 G4Polyhedron (HepPolyhedronEllipticalCone (a 144 G4Polyhedron (HepPolyhedronEllipticalCone (ax, ay, h, zCut1)) {} 176 145 177 G4PolyhedronEllipticalCone::~G4PolyhedronEllip << 146 G4PolyhedronEllipticalCone::~G4PolyhedronEllipticalCone () {} 178 << 179 G4PolyhedronHyperbolicMirror::G4PolyhedronHype << 180 << 181 << 182 G4Polyhedron (HepPolyhedronHyperbolicMirror( << 183 << 184 G4PolyhedronHyperbolicMirror::~G4PolyhedronHyp << 185 << 186 G4PolyhedronTetMesh:: << 187 G4PolyhedronTetMesh(const std::vector<G4ThreeV << 188 G4Polyhedron (HepPolyhedronTetMesh(tetrahedr << 189 147 190 G4PolyhedronTetMesh::~G4PolyhedronTetMesh () = << 148 std::ostream& operator<<(std::ostream& os, const G4Polyhedron& polyhedron) { 191 << 192 G4PolyhedronBoxMesh:: << 193 G4PolyhedronBoxMesh(G4double sizeX, G4double s << 194 const std::vector<G4ThreeV << 195 G4Polyhedron (HepPolyhedronBoxMesh(sizeX, si << 196 << 197 G4PolyhedronBoxMesh::~G4PolyhedronBoxMesh () = << 198 << 199 std::ostream& operator<<(std::ostream& os, con << 200 { << 201 os << "G4Polyhedron: " 149 os << "G4Polyhedron: " 202 << (const G4Visible&)polyhedron << '\n' 150 << (const G4Visible&)polyhedron << '\n' 203 << (const HepPolyhedron&)polyhedron; 151 << (const HepPolyhedron&)polyhedron; 204 return os; 152 return os; 205 } 153 } 206 154