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