70 :
G4VSolid(pName), createdDisplacedSolid(true)
84 :
G4VSolid(pName), createdDisplacedSolid(true)
106 if(createdDisplacedSolid)
110 delete fpPolyhedron; fpPolyhedron =
nullptr;
120 fCubVolStatistics(rhs.fCubVolStatistics),
121 fAreaStatistics(rhs.fAreaStatistics),
122 fCubVolEpsilon(rhs.fCubVolEpsilon),
123 fAreaAccuracy(rhs.fAreaAccuracy),
124 createdDisplacedSolid(rhs.createdDisplacedSolid)
126 fPrimitives.resize(0); fPrimitivesSurfaceArea = 0.;
137 if (
this == &rhs) {
return *
this; }
147 fCubVolStatistics = rhs.fCubVolStatistics; fCubVolEpsilon = rhs.fCubVolEpsilon;
148 fAreaStatistics = rhs.fAreaStatistics; fAreaAccuracy = rhs.fAreaAccuracy;
149 createdDisplacedSolid= rhs.createdDisplacedSolid;
151 fRebuildPolyhedron =
false;
152 delete fpPolyhedron; fpPolyhedron =
nullptr;
153 fPrimitives.resize(0); fPrimitivesSurfaceArea = 0.;
174 G4Exception(
"G4BooleanSolid::GetConstituentSolid()",
196 G4Exception(
"G4BooleanSolid::GetConstituentSolid()",
208 return {
"G4BooleanSolid"};
218 fCubVolStatistics = st;
227 if (type ==
"G4DisplacedSolid")
232 if (type ==
"G4ReflectedSolid")
237 if (type ==
"G4ScaledSolid")
242 if (type !=
"G4MultiUnion")
257 if (type ==
"G4DisplacedSolid")
262 if (type ==
"G4ReflectedSolid")
267 if (type ==
"G4ScaledSolid")
272 if (type !=
"G4MultiUnion")
297 if (type ==
"G4DisplacedSolid")
302 if (type ==
"G4ReflectedSolid")
307 if (type ==
"G4ScaledSolid")
312 if (type !=
"G4MultiUnion")
327 if (type ==
"G4DisplacedSolid")
332 if (type ==
"G4ReflectedSolid")
337 if (type ==
"G4ScaledSolid")
342 if (type !=
"G4MultiUnion")
357 os <<
"-----------------------------------------------------------\n"
358 <<
" *** Dump for Boolean solid - " <<
GetName() <<
" ***\n"
359 <<
" ===================================================\n"
361 <<
" Parameters of constituent solids: \n"
362 <<
"===========================================================\n";
365 os <<
"===========================================================\n";
375 std::vector<std::pair<G4VSolid*,G4Transform3D>>& primitives,
384 for (
auto i=0; i<2; ++i)
386 transform = curPlacement;
392 while (type ==
"G4DisplacedSolid" ||
393 type ==
"G4ReflectedSolid" ||
394 type ==
"G4ScaledSolid")
396 if (type ==
"G4DisplacedSolid")
403 else if (type ==
"G4ReflectedSolid")
408 else if (type ==
"G4ScaledSolid")
410 transform = transform * ((
G4ScaledSolid*)solid)->GetScaleTransform();
419 if (type ==
"G4UnionSolid" ||
420 type ==
"G4SubtractionSolid" ||
421 type ==
"G4IntersectionSolid" ||
422 type ==
"G4BooleanSolid")
424 ((
G4BooleanSolid *)solid)->GetListOfPrimitives(primitives,transform);
428 primitives.emplace_back(solid,transform);
440 std::size_t nprims = fPrimitives.size();
441 std::pair<G4VSolid *, G4Transform3D> prim;
448 nprims = fPrimitives.size();
449 fPrimitivesSurfaceArea = 0.;
450 for (std::size_t i=0; i<nprims; ++i)
452 fPrimitivesSurfaceArea += fPrimitives[i].first->GetSurfaceArea();
460 for (std::size_t k=0; k<100000; ++k)
464 for (std::size_t i=0; i<nprims; ++i)
466 prim = fPrimitives[i];
467 area += prim.first->GetSurfaceArea();
468 if (rand < area)
break;
470 p = prim.first->GetPointOnSurface();
474 std::ostringstream message;
475 message <<
"Solid - " <<
GetName() <<
"\n"
476 <<
"All 100k attempts to generate a point on the surface have failed!\n"
477 <<
"The solid created may be an invalid Boolean construct!";
507 if (fpPolyhedron ==
nullptr ||
508 fRebuildPolyhedron ||
509 fpPolyhedron->GetNumberOfRotationStepsAtTimeOfCreation() !=
510 fpPolyhedron->GetNumberOfRotationSteps())
515 fRebuildPolyhedron =
false;
531 if (type ==
"G4UnionSolid")
533 else if (type ==
"G4IntersectionSolid")
535 else if (type ==
"G4SubtractionSolid")
539 std::ostringstream message;
540 message <<
"Solid - " << solid->
GetName()
541 <<
" - Unrecognised composite solid" <<
G4endl
542 <<
" Returning NULL !";
560 if (operand !=
nullptr)
562 processor.
push_back (operation, *operand);
566 std::ostringstream message;
567 message <<
"Solid - " << solid->
GetName()
568 <<
" - No G4Polyhedron for Boolean component";
G4TemplateAutoLock< G4RecursiveMutex > G4RecursiveAutoLock
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
HepGeom::Point3D< G4double > G4Point3D
CLHEP::HepRotation G4RotationMatrix
#define G4MUTEX_INITIALIZER
std::recursive_mutex G4RecursiveMutex
CLHEP::Hep3Vector G4ThreeVector
G4BooleanSolid & operator=(const G4BooleanSolid &rhs)
void SetCubVolEpsilon(G4double ep)
G4Polyhedron * GetPolyhedron() const override
const G4VSolid * GetConstituentSolid(G4int no) const override
~G4BooleanSolid() override
void GetListOfPrimitives(std::vector< std::pair< G4VSolid *, G4Transform3D > > &, const G4Transform3D &) const
G4double GetCubicVolume() override
G4GeometryType GetEntityType() const override
G4BooleanSolid(const G4String &pName, G4VSolid *pSolidA, G4VSolid *pSolidB)
static G4VBooleanProcessor * GetExternalBooleanProcessor()
G4int GetNumOfConstituents() const override
static G4VBooleanProcessor * fExternalBoolProcessor
G4Polyhedron * StackPolyhedron(HepPolyhedronProcessor &, const G4VSolid *) const
std::ostream & StreamInfo(std::ostream &os) const override
void SetCubVolStatistics(G4int st)
G4bool IsFaceted() const override
static void SetExternalBooleanProcessor(G4VBooleanProcessor *extProcessor)
G4ThreeVector GetPointOnSurface() const override
G4VSolid * GetConstituentMovedSolid() const
virtual const G4VSolid * GetConstituentSolid(G4int no) const
G4double EstimateCubicVolume(G4int nStat, G4double epsilon) const
G4VSolid(const G4String &name)
virtual EInside Inside(const G4ThreeVector &p) const =0
virtual G4Polyhedron * GetPolyhedron() const
virtual G4Polyhedron * CreatePolyhedron() const
G4VSolid & operator=(const G4VSolid &rhs)
virtual G4GeometryType GetEntityType() const =0
void push_back(Operation, const HepPolyhedron &)