55 #ifndef G4PolyconeSide_hh
56 #define G4PolyconeSide_hh
85 std::pair<G4ThreeVector, G4double>
fPhi;
98 #define G4MT_pcphi ((subInstanceManager.offset[instanceID]).fPhi)
G4ThreeVector GetPointOnFace()
static G4GEOM_DLL G4PlSideManager subInstanceManager
CLHEP::Hep3Vector G4ThreeVector
static const G4float tolerance
G4bool Intersect(const G4ThreeVector &p, const G4ThreeVector &v, G4bool outgoing, G4double surfTolerance, G4double &distance, G4double &distFromSurface, G4ThreeVector &normal, G4bool &isAllBehind)
EInside Inside(const G4ThreeVector &p, G4double tolerance, G4double *bestDistance)
G4double Extent(const G4ThreeVector axis)
G4ThreeVector Normal(const G4ThreeVector &p, G4double *bestDistance)
void CopyStuff(const G4PolyconeSide &source)
static void FindLineIntersect(G4double x1, G4double y1, G4double tx1, G4double ty1, G4double x2, G4double y2, G4double tx2, G4double ty2, G4double &x, G4double &y)
virtual ~G4PolyconeSide()
static double normal(HepRandomEngine *eptr)
G4int GetInstanceID() const
void CalculateExtent(const EAxis axis, const G4VoxelLimits &voxelLimit, const G4AffineTransform &tranform, G4SolidExtentList &extentList)
G4PolyconeSide(const G4PolyconeSideRZ *prevRZ, const G4PolyconeSideRZ *tail, const G4PolyconeSideRZ *head, const G4PolyconeSideRZ *nextRZ, G4double phiStart, G4double deltaPhi, G4bool phiIsOpen, G4bool isAllBehind=false)
static const G4PlSideManager & GetSubInstanceManager()
std::pair< G4ThreeVector, G4double > fPhi
G4IntersectingCone * cone
G4double GetPhi(const G4ThreeVector &p)
const G4double x[NPOINTSGL]
G4double DistanceAway(const G4ThreeVector &p, G4bool opposite, G4double &distOutside2, G4double *rzNorm=0)
G4bool PointOnCone(const G4ThreeVector &hit, G4double normSign, const G4ThreeVector &p, const G4ThreeVector &v, G4ThreeVector &normal)
G4double Distance(const G4ThreeVector &p, G4bool outgoing)
G4GeomSplitter< G4PlSideData > G4PlSideManager
G4PolyconeSide & operator=(const G4PolyconeSide &source)