Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4BooleanSolid Class Reference

#include <G4BooleanSolid.hh>

+ Inheritance diagram for G4BooleanSolid:

Public Member Functions

 G4BooleanSolid (const G4String &pName, G4VSolid *pSolidA, G4VSolid *pSolidB)
 
 G4BooleanSolid (const G4String &pName, G4VSolid *pSolidA, G4VSolid *pSolidB, G4RotationMatrix *rotMatrix, const G4ThreeVector &transVector)
 
 G4BooleanSolid (const G4String &pName, G4VSolid *pSolidA, G4VSolid *pSolidB, const G4Transform3D &transform)
 
 ~G4BooleanSolid () override
 
const G4VSolidGetConstituentSolid (G4int no) const override
 
G4VSolidGetConstituentSolid (G4int no) override
 
G4double GetCubicVolume () override
 
G4double GetSurfaceArea () override
 
G4GeometryType GetEntityType () const override
 
G4PolyhedronGetPolyhedron () const override
 
std::ostream & StreamInfo (std::ostream &os) const override
 
G4int GetCubVolStatistics () const
 
G4double GetCubVolEpsilon () const
 
void SetCubVolStatistics (G4int st)
 
void SetCubVolEpsilon (G4double ep)
 
G4int GetAreaStatistics () const
 
G4double GetAreaAccuracy () const
 
void SetAreaStatistics (G4int st)
 
void SetAreaAccuracy (G4double ep)
 
G4ThreeVector GetPointOnSurface () const override
 
G4int GetNumOfConstituents () const override
 
G4bool IsFaceted () const override
 
 G4BooleanSolid (__void__ &)
 
 G4BooleanSolid (const G4BooleanSolid &rhs)
 
G4BooleanSolidoperator= (const G4BooleanSolid &rhs)
 
- Public Member Functions inherited from G4VSolid
 G4VSolid (const G4String &name)
 
virtual ~G4VSolid ()
 
G4bool operator== (const G4VSolid &s) const
 
G4String GetName () const
 
void SetName (const G4String &name)
 
G4double GetTolerance () const
 
virtual void BoundingLimits (G4ThreeVector &pMin, G4ThreeVector &pMax) const
 
virtual G4bool CalculateExtent (const EAxis pAxis, const G4VoxelLimits &pVoxelLimit, const G4AffineTransform &pTransform, G4double &pMin, G4double &pMax) const =0
 
virtual EInside Inside (const G4ThreeVector &p) const =0
 
virtual G4ThreeVector SurfaceNormal (const G4ThreeVector &p) const =0
 
virtual G4double DistanceToIn (const G4ThreeVector &p, const G4ThreeVector &v) const =0
 
virtual G4double DistanceToIn (const G4ThreeVector &p) const =0
 
virtual G4double DistanceToOut (const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcNorm=false, G4bool *validNorm=nullptr, G4ThreeVector *n=nullptr) const =0
 
virtual G4double DistanceToOut (const G4ThreeVector &p) const =0
 
virtual void ComputeDimensions (G4VPVParameterisation *p, const G4int n, const G4VPhysicalVolume *pRep)
 
virtual G4VSolidClone () const
 
void DumpInfo () const
 
virtual void DescribeYourselfTo (G4VGraphicsScene &scene) const =0
 
virtual G4VisExtent GetExtent () const
 
virtual G4PolyhedronCreatePolyhedron () const
 
virtual const G4DisplacedSolidGetDisplacedSolidPtr () const
 
virtual G4DisplacedSolidGetDisplacedSolidPtr ()
 
 G4VSolid (__void__ &)
 
 G4VSolid (const G4VSolid &rhs)
 
G4VSolidoperator= (const G4VSolid &rhs)
 
G4double EstimateCubicVolume (G4int nStat, G4double epsilon) const
 
G4double EstimateSurfaceArea (G4int nStat, G4double ell) const
 

Static Public Member Functions

static void SetExternalBooleanProcessor (G4VBooleanProcessor *extProcessor)
 
static G4VBooleanProcessorGetExternalBooleanProcessor ()
 

Protected Member Functions

void GetListOfPrimitives (std::vector< std::pair< G4VSolid *, G4Transform3D > > &, const G4Transform3D &) const
 
G4PolyhedronStackPolyhedron (HepPolyhedronProcessor &, const G4VSolid *) const
 
- Protected Member Functions inherited from G4VSolid
void CalculateClippedPolygonExtent (G4ThreeVectorList &pPolygon, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
 
void ClipCrossSection (G4ThreeVectorList *pVertices, const G4int pSectionIndex, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
 
void ClipBetweenSections (G4ThreeVectorList *pVertices, const G4int pSectionIndex, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis, G4double &pMin, G4double &pMax) const
 
void ClipPolygon (G4ThreeVectorList &pPolygon, const G4VoxelLimits &pVoxelLimit, const EAxis pAxis) const
 

Protected Attributes

G4VSolidfPtrSolidA = nullptr
 
G4VSolidfPtrSolidB = nullptr
 
G4double fCubicVolume = -1.0
 
G4double fSurfaceArea = -1.0
 
- Protected Attributes inherited from G4VSolid
G4double kCarTolerance
 

Static Protected Attributes

static G4VBooleanProcessorfExternalBoolProcessor = nullptr
 

Detailed Description

Definition at line 49 of file G4BooleanSolid.hh.

Constructor & Destructor Documentation

◆ G4BooleanSolid() [1/5]

◆ G4BooleanSolid() [2/5]

G4BooleanSolid::G4BooleanSolid ( const G4String & pName,
G4VSolid * pSolidA,
G4VSolid * pSolidB,
G4RotationMatrix * rotMatrix,
const G4ThreeVector & transVector )

Definition at line 65 of file G4BooleanSolid.cc.

70 : G4VSolid(pName), createdDisplacedSolid(true)
71{
72 fPtrSolidA = pSolidA ;
73 fPtrSolidB = new G4DisplacedSolid("placedB",pSolidB,rotMatrix,transVector) ;
74}

◆ G4BooleanSolid() [3/5]

G4BooleanSolid::G4BooleanSolid ( const G4String & pName,
G4VSolid * pSolidA,
G4VSolid * pSolidB,
const G4Transform3D & transform )

Definition at line 80 of file G4BooleanSolid.cc.

84 : G4VSolid(pName), createdDisplacedSolid(true)
85{
86 fPtrSolidA = pSolidA ;
87 fPtrSolidB = new G4DisplacedSolid("placedB",pSolidB,transform) ;
88}

◆ ~G4BooleanSolid()

G4BooleanSolid::~G4BooleanSolid ( )
override

Definition at line 104 of file G4BooleanSolid.cc.

105{
106 if(createdDisplacedSolid)
107 {
108 ((G4DisplacedSolid*)fPtrSolidB)->CleanTransformations();
109 }
110 delete fpPolyhedron; fpPolyhedron = nullptr;
111}

◆ G4BooleanSolid() [4/5]

G4BooleanSolid::G4BooleanSolid ( __void__ & a)

Definition at line 95 of file G4BooleanSolid.cc.

96 : G4VSolid(a)
97{
98}

◆ G4BooleanSolid() [5/5]

G4BooleanSolid::G4BooleanSolid ( const G4BooleanSolid & rhs)

Definition at line 117 of file G4BooleanSolid.cc.

120 fCubVolStatistics(rhs.fCubVolStatistics),
121 fAreaStatistics(rhs.fAreaStatistics),
122 fCubVolEpsilon(rhs.fCubVolEpsilon),
123 fAreaAccuracy(rhs.fAreaAccuracy),
124 createdDisplacedSolid(rhs.createdDisplacedSolid)
125{
126 fPrimitives.resize(0); fPrimitivesSurfaceArea = 0.;
127}

Member Function Documentation

◆ GetAreaAccuracy()

G4double G4BooleanSolid::GetAreaAccuracy ( ) const
inline

◆ GetAreaStatistics()

G4int G4BooleanSolid::GetAreaStatistics ( ) const
inline

◆ GetConstituentSolid() [1/2]

const G4VSolid * G4BooleanSolid::GetConstituentSolid ( G4int no) const
overridevirtual

Reimplemented from G4VSolid.

Definition at line 164 of file G4BooleanSolid.cc.

165{
166 const G4VSolid* subSolid = nullptr;
167 if( no == 0 )
168 subSolid = fPtrSolidA;
169 else if( no == 1 )
170 subSolid = fPtrSolidB;
171 else
172 {
173 DumpInfo();
174 G4Exception("G4BooleanSolid::GetConstituentSolid()",
175 "GeomSolids0002", FatalException, "Invalid solid index.");
176 }
177 return subSolid;
178}
@ FatalException
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
void DumpInfo() const

Referenced by G4tgbGeometryDumper::DumpBooleanVolume().

◆ GetConstituentSolid() [2/2]

G4VSolid * G4BooleanSolid::GetConstituentSolid ( G4int no)
overridevirtual

Reimplemented from G4VSolid.

Definition at line 186 of file G4BooleanSolid.cc.

187{
188 G4VSolid* subSolid = nullptr;
189 if( no == 0 )
190 subSolid = fPtrSolidA;
191 else if( no == 1 )
192 subSolid = fPtrSolidB;
193 else
194 {
195 DumpInfo();
196 G4Exception("G4BooleanSolid::GetConstituentSolid()",
197 "GeomSolids0002", FatalException, "Invalid solid index.");
198 }
199 return subSolid;
200}

◆ GetCubicVolume()

G4double G4BooleanSolid::GetCubicVolume ( )
overridevirtual

Reimplemented from G4VSolid.

Reimplemented in G4SubtractionSolid, and G4UnionSolid.

Definition at line 581 of file G4BooleanSolid.cc.

582{
583 if(fCubicVolume < 0.)
584 {
585 fCubicVolume = EstimateCubicVolume(fCubVolStatistics, fCubVolEpsilon);
586 }
587 return fCubicVolume;
588}
G4double EstimateCubicVolume(G4int nStat, G4double epsilon) const
Definition G4VSolid.cc:218

Referenced by G4SubtractionSolid::GetCubicVolume(), and G4UnionSolid::GetCubicVolume().

◆ GetCubVolEpsilon()

G4double G4BooleanSolid::GetCubVolEpsilon ( ) const
inline

◆ GetCubVolStatistics()

G4int G4BooleanSolid::GetCubVolStatistics ( ) const
inline

◆ GetEntityType()

G4GeometryType G4BooleanSolid::GetEntityType ( ) const
overridevirtual

Implements G4VSolid.

Reimplemented in G4IntersectionSolid, G4SubtractionSolid, and G4UnionSolid.

Definition at line 206 of file G4BooleanSolid.cc.

207{
208 return {"G4BooleanSolid"};
209}

Referenced by StreamInfo().

◆ GetExternalBooleanProcessor()

G4VBooleanProcessor * G4BooleanSolid::GetExternalBooleanProcessor ( )
static

Definition at line 604 of file G4BooleanSolid.cc.

605{
607}
static G4VBooleanProcessor * fExternalBoolProcessor

Referenced by G4MultiUnion::CreatePolyhedron().

◆ GetListOfPrimitives()

void G4BooleanSolid::GetListOfPrimitives ( std::vector< std::pair< G4VSolid *, G4Transform3D > > & primitives,
const G4Transform3D & curPlacement ) const
protected

Definition at line 374 of file G4BooleanSolid.cc.

377{
378 G4Transform3D transform;
379 G4VSolid* solid;
380 G4String type;
381
382 // Repeat two times, first time for fPtrSolidA and then for fPtrSolidB
383 //
384 for (auto i=0; i<2; ++i)
385 {
386 transform = curPlacement;
387 solid = (i == 0) ? fPtrSolidA : fPtrSolidB;
388 type = solid->GetEntityType();
389
390 // While current solid is a trasformed solid just modify transform
391 //
392 while (type == "G4DisplacedSolid" ||
393 type == "G4ReflectedSolid" ||
394 type == "G4ScaledSolid")
395 {
396 if (type == "G4DisplacedSolid")
397 {
398 transform = transform * G4Transform3D(
399 ((G4DisplacedSolid*)solid)->GetObjectRotation(),
400 ((G4DisplacedSolid*)solid)->GetObjectTranslation());
401 solid = ((G4DisplacedSolid*)solid)->GetConstituentMovedSolid();
402 }
403 else if (type == "G4ReflectedSolid")
404 {
405 transform= transform*((G4ReflectedSolid*)solid)->GetDirectTransform3D();
406 solid = ((G4ReflectedSolid*)solid)->GetConstituentMovedSolid();
407 }
408 else if (type == "G4ScaledSolid")
409 {
410 transform = transform * ((G4ScaledSolid*)solid)->GetScaleTransform();
411 solid = ((G4ScaledSolid*)solid)->GetUnscaledSolid();
412 }
413 type = solid->GetEntityType();
414 }
415
416 // If current solid is a Boolean solid then continue recursion,
417 // otherwise add it to the list of primitives
418 //
419 if (type == "G4UnionSolid" ||
420 type == "G4SubtractionSolid" ||
421 type == "G4IntersectionSolid" ||
422 type == "G4BooleanSolid")
423 {
424 ((G4BooleanSolid *)solid)->GetListOfPrimitives(primitives,transform);
425 }
426 else
427 {
428 primitives.emplace_back(solid,transform);
429 }
430 }
431}
HepGeom::Transform3D G4Transform3D
G4BooleanSolid(const G4String &pName, G4VSolid *pSolidA, G4VSolid *pSolidB)
G4VSolid * GetConstituentMovedSolid() const
G4GeometryType GetEntityType() const override
virtual G4GeometryType GetEntityType() const =0

Referenced by GetPointOnSurface().

◆ GetNumOfConstituents()

G4int G4BooleanSolid::GetNumOfConstituents ( ) const
overridevirtual

Reimplemented from G4VSolid.

Definition at line 487 of file G4BooleanSolid.cc.

488{
489 return (fPtrSolidA->GetNumOfConstituents() + fPtrSolidB->GetNumOfConstituents());
490}

Referenced by G4SubtractionSolid::GetCubicVolume(), and G4UnionSolid::GetCubicVolume().

◆ GetPointOnSurface()

G4ThreeVector G4BooleanSolid::GetPointOnSurface ( ) const
overridevirtual

Reimplemented from G4VSolid.

Definition at line 438 of file G4BooleanSolid.cc.

439{
440 std::size_t nprims = fPrimitives.size();
441 std::pair<G4VSolid *, G4Transform3D> prim;
442
443 // Get list of primitives and find the total area of their surfaces
444 //
445 if (nprims == 0)
446 {
447 GetListOfPrimitives(fPrimitives, G4Transform3D());
448 nprims = fPrimitives.size();
449 fPrimitivesSurfaceArea = 0.;
450 for (std::size_t i=0; i<nprims; ++i)
451 {
452 fPrimitivesSurfaceArea += fPrimitives[i].first->GetSurfaceArea();
453 }
454 }
455
456 // Select random primitive, get random point on its surface and
457 // check that the point belongs to the surface of the solid
458 //
460 for (std::size_t k=0; k<100000; ++k) // try 100k times
461 {
462 G4double rand = fPrimitivesSurfaceArea * G4QuickRand();
463 G4double area = 0.;
464 for (std::size_t i=0; i<nprims; ++i)
465 {
466 prim = fPrimitives[i];
467 area += prim.first->GetSurfaceArea();
468 if (rand < area) break;
469 }
470 p = prim.first->GetPointOnSurface();
471 p = prim.second * G4Point3D(p);
472 if (Inside(p) == kSurface) return p;
473 }
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!";
478 G4Exception("G4BooleanSolid::GetPointOnSurface()",
479 "GeomSolids1001", JustWarning, message);
480 return p;
481}
@ JustWarning
HepGeom::Point3D< G4double > G4Point3D
Definition G4Point3D.hh:34
G4double G4QuickRand()
CLHEP::Hep3Vector G4ThreeVector
double G4double
Definition G4Types.hh:83
void GetListOfPrimitives(std::vector< std::pair< G4VSolid *, G4Transform3D > > &, const G4Transform3D &) const
G4String GetName() const
virtual EInside Inside(const G4ThreeVector &p) const =0
@ kSurface
Definition geomdefs.hh:69

◆ GetPolyhedron()

G4Polyhedron * G4BooleanSolid::GetPolyhedron ( ) const
overridevirtual

Reimplemented from G4VSolid.

Definition at line 505 of file G4BooleanSolid.cc.

506{
507 if (fpPolyhedron == nullptr ||
508 fRebuildPolyhedron ||
509 fpPolyhedron->GetNumberOfRotationStepsAtTimeOfCreation() !=
510 fpPolyhedron->GetNumberOfRotationSteps())
511 {
512 G4RecursiveAutoLock l(&polyhedronMutex);
513 delete fpPolyhedron;
514 fpPolyhedron = CreatePolyhedron();
515 fRebuildPolyhedron = false;
516 l.unlock();
517 }
518 return fpPolyhedron;
519}
G4TemplateAutoLock< G4RecursiveMutex > G4RecursiveAutoLock
virtual G4Polyhedron * CreatePolyhedron() const
Definition G4VSolid.cc:715

◆ GetSurfaceArea()

G4double G4BooleanSolid::GetSurfaceArea ( )
inlineoverridevirtual

Reimplemented from G4VSolid.

◆ IsFaceted()

G4bool G4BooleanSolid::IsFaceted ( ) const
overridevirtual

Reimplemented from G4VSolid.

Definition at line 496 of file G4BooleanSolid.cc.

497{
498 return (fPtrSolidA->IsFaceted() && fPtrSolidB->IsFaceted());
499}

◆ operator=()

G4BooleanSolid & G4BooleanSolid::operator= ( const G4BooleanSolid & rhs)

Definition at line 133 of file G4BooleanSolid.cc.

134{
135 // Check assignment to self
136 //
137 if (this == &rhs) { return *this; }
138
139 // Copy base class data
140 //
142
143 // Copy data
144 //
147 fCubVolStatistics = rhs.fCubVolStatistics; fCubVolEpsilon = rhs.fCubVolEpsilon;
148 fAreaStatistics = rhs.fAreaStatistics; fAreaAccuracy = rhs.fAreaAccuracy;
149 createdDisplacedSolid= rhs.createdDisplacedSolid;
150
151 fRebuildPolyhedron = false;
152 delete fpPolyhedron; fpPolyhedron = nullptr;
153 fPrimitives.resize(0); fPrimitivesSurfaceArea = 0.;
154
155 return *this;
156}
G4VSolid & operator=(const G4VSolid &rhs)
Definition G4VSolid.cc:107

Referenced by G4IntersectionSolid::operator=(), G4SubtractionSolid::operator=(), and G4UnionSolid::operator=().

◆ SetAreaAccuracy()

void G4BooleanSolid::SetAreaAccuracy ( G4double ep)
inline

◆ SetAreaStatistics()

void G4BooleanSolid::SetAreaStatistics ( G4int st)
inline

◆ SetCubVolEpsilon()

void G4BooleanSolid::SetCubVolEpsilon ( G4double ep)

Definition at line 285 of file G4BooleanSolid.cc.

286{
287 if (ep != fCubVolEpsilon) { fCubicVolume = -1.; }
288 fCubVolEpsilon = ep;
289
290 // Propagate ep to all components of the 1st solid
291 if (fPtrSolidA->GetNumOfConstituents() > 1)
292 {
293 G4VSolid* ptr = fPtrSolidA;
294 while(true)
295 {
296 G4String type = ptr->GetEntityType();
297 if (type == "G4DisplacedSolid")
298 {
299 ptr = ((G4DisplacedSolid*)ptr)->GetConstituentMovedSolid();
300 continue;
301 }
302 if (type == "G4ReflectedSolid")
303 {
304 ptr = ((G4ReflectedSolid*)ptr)->GetConstituentMovedSolid();
305 continue;
306 }
307 if (type == "G4ScaledSolid")
308 {
309 ptr = ((G4ScaledSolid*)ptr)->GetUnscaledSolid();
310 continue;
311 }
312 if (type != "G4MultiUnion") // G4MultiUnion doesn't have SetCubVolEpsilon()
313 {
314 ((G4BooleanSolid*)ptr)->SetCubVolEpsilon(ep);
315 }
316 break;
317 }
318 }
319
320 // Propagate ep to all components of the 2nd solid
321 if (fPtrSolidB->GetNumOfConstituents() > 1)
322 {
323 G4VSolid* ptr = fPtrSolidB;
324 while(true)
325 {
326 G4String type = ptr->GetEntityType();
327 if (type == "G4DisplacedSolid")
328 {
329 ptr = ((G4DisplacedSolid*)ptr)->GetConstituentMovedSolid();
330 continue;
331 }
332 if (type == "G4ReflectedSolid")
333 {
334 ptr = ((G4ReflectedSolid*)ptr)->GetConstituentMovedSolid();
335 continue;
336 }
337 if (type == "G4ScaledSolid")
338 {
339 ptr = ((G4ScaledSolid*)ptr)->GetUnscaledSolid();
340 continue;
341 }
342 if (type != "G4MultiUnion") // G4MultiUnion doesn't have SetCubVolEpsilon()
343 {
344 ((G4BooleanSolid*)ptr)->SetCubVolEpsilon(ep);
345 }
346 break;
347 }
348 }
349}

Referenced by G4SubtractionSolid::GetCubicVolume(), and G4UnionSolid::GetCubicVolume().

◆ SetCubVolStatistics()

void G4BooleanSolid::SetCubVolStatistics ( G4int st)

Definition at line 215 of file G4BooleanSolid.cc.

216{
217 if (st != fCubVolStatistics) { fCubicVolume = -1.; }
218 fCubVolStatistics = st;
219
220 // Propagate st to all components of the 1st solid
221 if (fPtrSolidA->GetNumOfConstituents() > 1)
222 {
223 G4VSolid* ptr = fPtrSolidA;
224 while(true)
225 {
226 G4String type = ptr->GetEntityType();
227 if (type == "G4DisplacedSolid")
228 {
229 ptr = ((G4DisplacedSolid*)ptr)->GetConstituentMovedSolid();
230 continue;
231 }
232 if (type == "G4ReflectedSolid")
233 {
234 ptr = ((G4ReflectedSolid*)ptr)->GetConstituentMovedSolid();
235 continue;
236 }
237 if (type == "G4ScaledSolid")
238 {
239 ptr = ((G4ScaledSolid*)ptr)->GetUnscaledSolid();
240 continue;
241 }
242 if (type != "G4MultiUnion") // G4MultiUnion doesn't have SetCubVolStatistics()
243 {
244 ((G4BooleanSolid*)ptr)->SetCubVolStatistics(st);
245 }
246 break;
247 }
248 }
249
250 // Propagate st to all components of the 2nd solid
251 if (fPtrSolidB->GetNumOfConstituents() > 1)
252 {
253 G4VSolid* ptr = fPtrSolidB;
254 while(true)
255 {
256 G4String type = ptr->GetEntityType();
257 if (type == "G4DisplacedSolid")
258 {
259 ptr = ((G4DisplacedSolid*)ptr)->GetConstituentMovedSolid();
260 continue;
261 }
262 if (type == "G4ReflectedSolid")
263 {
264 ptr = ((G4ReflectedSolid*)ptr)->GetConstituentMovedSolid();
265 continue;
266 }
267 if (type == "G4ScaledSolid")
268 {
269 ptr = ((G4ScaledSolid*)ptr)->GetUnscaledSolid();
270 continue;
271 }
272 if (type != "G4MultiUnion") // G4MultiUnion doesn't have SetCubVolStatistics()
273 {
274 ((G4BooleanSolid*)ptr)->SetCubVolStatistics(st);
275 }
276 break;
277 }
278 }
279}

Referenced by G4SubtractionSolid::GetCubicVolume(), and G4UnionSolid::GetCubicVolume().

◆ SetExternalBooleanProcessor()

void G4BooleanSolid::SetExternalBooleanProcessor ( G4VBooleanProcessor * extProcessor)
static

Definition at line 595 of file G4BooleanSolid.cc.

596{
597 fExternalBoolProcessor = extProcessor;
598}

◆ StackPolyhedron()

G4Polyhedron * G4BooleanSolid::StackPolyhedron ( HepPolyhedronProcessor & processor,
const G4VSolid * solid ) const
protected

Definition at line 526 of file G4BooleanSolid.cc.

528{
530 const G4String& type = solid->GetEntityType();
531 if (type == "G4UnionSolid")
532 { operation = HepPolyhedronProcessor::UNION; }
533 else if (type == "G4IntersectionSolid")
535 else if (type == "G4SubtractionSolid")
537 else
538 {
539 std::ostringstream message;
540 message << "Solid - " << solid->GetName()
541 << " - Unrecognised composite solid" << G4endl
542 << " Returning NULL !";
543 G4Exception("StackPolyhedron()", "GeomSolids1001", JustWarning, message);
544 return nullptr;
545 }
546
547 G4Polyhedron* top = nullptr;
548 const G4VSolid* solidA = solid->GetConstituentSolid(0);
549 const G4VSolid* solidB = solid->GetConstituentSolid(1);
550
551 if (solidA->GetConstituentSolid(0) != nullptr)
552 {
553 top = StackPolyhedron(processor, solidA);
554 }
555 else
556 {
557 top = solidA->GetPolyhedron();
558 }
559 G4Polyhedron* operand = solidB->GetPolyhedron();
560 if (operand != nullptr)
561 {
562 processor.push_back (operation, *operand);
563 }
564 else
565 {
566 std::ostringstream message;
567 message << "Solid - " << solid->GetName()
568 << " - No G4Polyhedron for Boolean component";
569 G4Exception("G4BooleanSolid::StackPolyhedron()",
570 "GeomSolids2001", JustWarning, message);
571 }
572
573 return top;
574}
#define G4endl
Definition G4ios.hh:67
G4Polyhedron * StackPolyhedron(HepPolyhedronProcessor &, const G4VSolid *) const
virtual const G4VSolid * GetConstituentSolid(G4int no) const
Definition G4VSolid.cc:182
virtual G4Polyhedron * GetPolyhedron() const
Definition G4VSolid.cc:720
void push_back(Operation, const HepPolyhedron &)

Referenced by G4IntersectionSolid::CreatePolyhedron(), G4SubtractionSolid::CreatePolyhedron(), G4UnionSolid::CreatePolyhedron(), and StackPolyhedron().

◆ StreamInfo()

std::ostream & G4BooleanSolid::StreamInfo ( std::ostream & os) const
overridevirtual

Implements G4VSolid.

Definition at line 355 of file G4BooleanSolid.cc.

356{
357 os << "-----------------------------------------------------------\n"
358 << " *** Dump for Boolean solid - " << GetName() << " ***\n"
359 << " ===================================================\n"
360 << " Solid type: " << GetEntityType() << "\n"
361 << " Parameters of constituent solids: \n"
362 << "===========================================================\n";
363 fPtrSolidA->StreamInfo(os);
364 fPtrSolidB->StreamInfo(os);
365 os << "===========================================================\n";
366
367 return os;
368}
G4GeometryType GetEntityType() const override

Member Data Documentation

◆ fCubicVolume

◆ fExternalBoolProcessor

◆ fPtrSolidA

◆ fPtrSolidB

◆ fSurfaceArea

G4double G4BooleanSolid::fSurfaceArea = -1.0
protected

Definition at line 130 of file G4BooleanSolid.hh.

Referenced by G4BooleanSolid(), and operator=().


The documentation for this class was generated from the following files: