44#ifndef G4GENERICPOLYCONE_HH
45#define G4GENERICPOLYCONE_HH
49#if defined(G4GEOM_USE_USOLIDS)
50#define G4GEOM_USE_UGENERICPOLYCONE 1
53#if defined(G4GEOM_USE_UGENERICPOLYCONE)
54 #define G4UGenericPolycone G4GenericPolycone
100 std::ostream&
StreamInfo(std::ostream& os)
const;
156 mutable std::vector<surface_element>*
fElements =
nullptr;
159#include "G4GenericPolycone.icc"
G4double GetSurfaceArea()
G4double DistanceToIn(const G4ThreeVector &p, const G4ThreeVector &v) const
void SetSurfaceElements() const
G4PolyconeSideRZ * corners
G4bool CalculateExtent(const EAxis pAxis, const G4VoxelLimits &pVoxelLimit, const G4AffineTransform &pTransform, G4double &pmin, G4double &pmax) const
G4EnclosingCylinder * enclosingCylinder
G4double GetStartPhi() const
void CopyStuff(const G4GenericPolycone &source)
G4GenericPolycone & operator=(const G4GenericPolycone &source)
G4double GetCubicVolume()
G4double GetEndPhi() const
G4int GetNumRZCorner() const
G4GeometryType GetEntityType() const
G4double GetCosEndPhi() const
G4double GetSinStartPhi() const
G4PolyconeSideRZ GetCorner(G4int index) const
G4ThreeVector GetPointOnSurface() const
G4double GetSinEndPhi() const
std::ostream & StreamInfo(std::ostream &os) const
void Create(G4double phiStart, G4double phiTotal, G4ReduciblePolygon *rz)
G4Polyhedron * CreatePolyhedron() const
void BoundingLimits(G4ThreeVector &pMin, G4ThreeVector &pMax) const
G4double GetCosStartPhi() const
std::vector< surface_element > * fElements
EInside Inside(const G4ThreeVector &p) const
virtual ~G4GenericPolycone()