111 if (
this == &rhs) {
return *
this; }
116 fshapeName = rhs.fshapeName;
141 std::ostringstream message;
142 message <<
"Illegal call to G4VSolid::ComputeDimensions()" <<
G4endl
143 <<
"Method not overloaded by derived class !";
144 G4Exception(
"G4VSolid::ComputeDimensions()",
"GeomMgt0003",
154 std::ostringstream message;
155 message <<
"Not implemented for solid: "
157 <<
"Returning origin.";
158 G4Exception(
"G4VSolid::GetPointOnSurface()",
"GeomMgt1001",
205 G4int cubVolStatistics = 1000000;
221 G4double px,py,pz,minX,maxX,minY,maxY,minZ,maxZ,volume,halfepsilon;
238 if(nStat < 100) nStat = 100;
242 for(
auto i = 0; i < nStat; ++i )
252 * (maxZ-minZ+
epsilon)*iInside/nStat;
267 G4int stat = 1000000;
282 static const G4double s2 = 1./std::sqrt(2.);
283 static const G4double s3 = 1./std::sqrt(3.);
336 G4int npoints = (nstat < 1000) ? 1000 : nstat;
338 G4double eps = (ell > 0) ? ell : coeff * std::min(std::min(dX, dY), dZ);
353 for(
auto i = 0; i < npoints; ++i)
371 if (icase == 0)
continue;
387 if (icase == 0)
continue;
390 if (dist == kInfinity)
continue;
394 if (dist < eps) ++icount;
396 return dX*dY*dZ*icount/npoints/dd;
408 std::ostringstream message;
409 message <<
"Clone() method not implemented for type: "
411 <<
"Returning NULL pointer!";
430 const G4int pSectionIndex,
438 polygon.push_back((*pVertices)[pSectionIndex]);
439 polygon.push_back((*pVertices)[pSectionIndex+1]);
440 polygon.push_back((*pVertices)[pSectionIndex+2]);
441 polygon.push_back((*pVertices)[pSectionIndex+3]);
460 const G4int pSectionIndex,
467 polygon.push_back((*pVertices)[pSectionIndex]);
468 polygon.push_back((*pVertices)[pSectionIndex+4]);
469 polygon.push_back((*pVertices)[pSectionIndex+5]);
470 polygon.push_back((*pVertices)[pSectionIndex+1]);
474 polygon.push_back((*pVertices)[pSectionIndex+1]);
475 polygon.push_back((*pVertices)[pSectionIndex+5]);
476 polygon.push_back((*pVertices)[pSectionIndex+6]);
477 polygon.push_back((*pVertices)[pSectionIndex+2]);
481 polygon.push_back((*pVertices)[pSectionIndex+2]);
482 polygon.push_back((*pVertices)[pSectionIndex+6]);
483 polygon.push_back((*pVertices)[pSectionIndex+7]);
484 polygon.push_back((*pVertices)[pSectionIndex+3]);
488 polygon.push_back((*pVertices)[pSectionIndex+3]);
489 polygon.push_back((*pVertices)[pSectionIndex+7]);
490 polygon.push_back((*pVertices)[pSectionIndex+4]);
491 polygon.push_back((*pVertices)[pSectionIndex]);
514 noLeft = (
G4int)pPolygon.size();
518 for (i=0; i<noLeft; ++i)
520 component = pPolygon[i].operator()(pAxis);
522 if (component < pMin)
526 if (component > pMax)
566 ClipPolygonToSimpleLimits(pPolygon,outputPolygon,simpleLimit1);
570 if ( outputPolygon.empty() )
return;
574 ClipPolygonToSimpleLimits(outputPolygon,pPolygon,simpleLimit2);
576 if ( pPolygon.empty() )
return;
577 else outputPolygon.clear();
583 ClipPolygonToSimpleLimits(pPolygon,outputPolygon,simpleLimit1);
590 if ( outputPolygon.empty() )
return;
594 ClipPolygonToSimpleLimits(outputPolygon,pPolygon,simpleLimit2);
596 if ( pPolygon.empty() )
return;
597 else outputPolygon.clear();
603 ClipPolygonToSimpleLimits(pPolygon,outputPolygon,simpleLimit1);
610 if ( outputPolygon.empty() )
return;
614 ClipPolygonToSimpleLimits(outputPolygon,pPolygon,simpleLimit2);
632 auto noVertices = (
G4int)pPolygon.size();
635 for (i = 0 ; i < noVertices ; ++i )
637 vStart = pPolygon[i];
638 if ( i == noVertices-1 ) vEnd = pPolygon[0];
639 else vEnd = pPolygon[i+1];
641 if ( pVoxelLimit.
Inside(vStart) )
643 if (pVoxelLimit.
Inside(vEnd))
647 outputPolygon.push_back(vEnd);
654 outputPolygon.push_back(vEnd);
659 if (pVoxelLimit.
Inside(vEnd))
664 outputPolygon.push_back(vStart);
665 outputPolygon.push_back(vEnd);
682 std::ostringstream message;
683 message <<
"Not implemented for solid: "
685 <<
"\nReturning infinite boundinx box.";
686 G4Exception(
"G4VSolid::BoundingLimits()",
"GeomMgt1001",
689 pMin.
set(-kInfinity,-kInfinity,-kInfinity);
690 pMax.
set( kInfinity, kInfinity, kInfinity);
std::vector< G4ThreeVector > G4ThreeVectorList
G4double epsilon(G4double density, G4double temperature)
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
CLHEP::Hep3Vector G4ThreeVector
std::ostream & operator<<(std::ostream &os, const G4VSolid &e)
Output solid information to given ostream.
std::vector< G4ThreeVector > G4ThreeVectorList
double dot(const Hep3Vector &) const
void set(double x, double y, double z)
G4double GetSurfaceTolerance() const
static G4GeometryTolerance * GetInstance()
static void Register(G4VSolid *pSolid)
void SetMapValid(G4bool val)
static void DeRegister(G4VSolid *pSolid)
static G4SolidStore * GetInstance()
G4double EstimateSurfaceArea(G4int nStat, G4double ell) const
virtual G4VSolid * Clone() const
virtual const G4VSolid * GetConstituentSolid(G4int no) const
virtual std::ostream & StreamInfo(std::ostream &os) const =0
void ClipBetweenSections(G4ThreeVectorList *pVertices, const G4int pSectionIndex, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
G4double EstimateCubicVolume(G4int nStat, G4double epsilon) const
virtual G4bool CalculateExtent(const EAxis pAxis, const G4VoxelLimits &pVoxelLimit, const G4AffineTransform &pTransform, G4double &pMin, G4double &pMax) const =0
virtual G4VisExtent GetExtent() const
virtual G4bool IsFaceted() const
G4VSolid(const G4String &name)
virtual EInside Inside(const G4ThreeVector &p) const =0
virtual void ComputeDimensions(G4VPVParameterisation *p, const G4int n, const G4VPhysicalVolume *pRep)
void SetName(const G4String &name)
virtual G4double DistanceToOut(const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcNorm=false, G4bool *validNorm=nullptr, G4ThreeVector *n=nullptr) const =0
virtual G4int GetNumOfConstituents() const
virtual G4ThreeVector GetPointOnSurface() const
void ClipPolygon(G4ThreeVectorList &pPolygon, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis) const
virtual G4ThreeVector SurfaceNormal(const G4ThreeVector &p) const =0
virtual G4Polyhedron * GetPolyhedron() const
virtual void BoundingLimits(G4ThreeVector &pMin, G4ThreeVector &pMax) const
virtual G4Polyhedron * CreatePolyhedron() const
G4VSolid & operator=(const G4VSolid &rhs)
virtual G4double DistanceToIn(const G4ThreeVector &p, const G4ThreeVector &v) const =0
virtual const G4DisplacedSolid * GetDisplacedSolidPtr() const
virtual G4double GetCubicVolume()
void ClipCrossSection(G4ThreeVectorList *pVertices, const G4int pSectionIndex, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
virtual G4double GetSurfaceArea()
void CalculateClippedPolygonExtent(G4ThreeVectorList &pPolygon, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
virtual G4GeometryType GetEntityType() const =0
void SetYmin(G4double ymin)
void SetYmax(G4double ymax)
void SetXmax(G4double xmax)
void SetXmin(G4double xmin)
void SetZmax(G4double zmax)
void SetZmin(G4double zmin)
G4bool IsYLimited() const
G4bool ClipToLimits(G4ThreeVector &pStart, G4ThreeVector &pEnd) const
G4double GetMinZExtent() const
void AddLimit(const EAxis pAxis, const G4double pMin, const G4double pMax)
G4bool IsXLimited() const
G4double GetMaxYExtent() const
G4bool Inside(const G4ThreeVector &pVec) const
G4double GetMaxZExtent() const
G4double GetMinYExtent() const
G4double GetMinXExtent() const
G4bool IsZLimited() const
G4double GetMaxXExtent() const