52 fmany(pMany), fallocatedRotM(false), fcopyNo(pCopyNo)
57 if (pLogical == motherLogical)
59 G4Exception(
"G4PVPlacement::G4PVPlacement()",
"GeomVol0002",
79 Transform3D.getTranslation(),pName,pLogical,pMother),
80 fmany(pMany), fcopyNo(pCopyNo)
86 if (pLogical == motherLogical)
87 G4Exception(
"G4PVPlacement::G4PVPlacement()",
"GeomVol0002",
109 fmany(pMany), fallocatedRotM(false), fcopyNo(pCopyNo)
111 if (pCurrentLogical == pMotherLogical)
113 G4Exception(
"G4PVPlacement::G4PVPlacement()",
"GeomVol0002",
117 if (pMotherLogical) { pMotherLogical->
AddDaughter(
this); }
133 fmany(pMany), fcopyNo(pCopyNo)
135 if (pCurrentLogical == pMotherLogical)
137 G4Exception(
"G4PVPlacement::G4PVPlacement()",
"GeomVol0002",
143 if (pMotherLogical) { pMotherLogical->
AddDaughter(
this); }
247 if (res<=0) {
return false; }
251 if (!motherLog) {
return false; }
260 G4cout <<
"Checking overlaps for volume " <<
GetName() <<
" ... ";
284 trials++; retval =
true;
285 std::ostringstream message;
286 message <<
"Overlap with mother volume !" <<
G4endl
287 <<
" Overlap is detected for volume "
289 <<
" with its mother volume "
291 <<
" at mother local point " << mp <<
", "
292 <<
"overlapping by at least: "
297 <<
"NOTE: Reached maximum fixed number -" << maxErr
298 <<
"- of overlaps reports for this volume !";
302 if (trials>=maxErr) {
return true; }
312 if (daughter ==
this) {
continue; }
326 trials++; retval =
true;
327 std::ostringstream message;
328 message <<
"Overlap with volume already placed !" <<
G4endl
329 <<
" Overlap is detected for volume "
331 <<
" with " << daughter->
GetName() <<
" volume's"
333 <<
" local point " << md <<
", "
334 <<
"overlapping by at least: "
339 <<
"NOTE: Reached maximum fixed number -" << maxErr
340 <<
"- of overlaps reports for this volume !";
344 if (trials>=maxErr) {
return true; }
366 trials++; retval =
true;
367 std::ostringstream message;
368 message <<
"Overlap with volume already placed !" <<
G4endl
369 <<
" Overlap is detected for volume "
371 <<
" apparently fully encapsulating volume "
373 <<
" at the same level !";
376 if (trials>=maxErr) {
return true; }
404 if ( RotMat.isIdentity() )
const G4ThreeVector & GetTranslation() const
CLHEP::Hep3Vector G4ThreeVector
CLHEP::HepRotation G4RotationMatrix
G4bool IsReplicated() const
G4VPhysicalVolume * GetDaughter(const G4int i) const
#define G4BestUnit(a, b)
#define G4_USE_G4BESTUNIT_FOR_VERBOSE 1
G4bool IsRegularStructure() const
void SetRotation(G4RotationMatrix *)
G4VPVParameterisation * GetParameterisation() const
G4GLOB_DLL std::ostream G4cout
const G4String & GetName() const
virtual EInside Inside(const G4ThreeVector &p) const =0
G4PVPlacement(G4RotationMatrix *pRot, const G4ThreeVector &tlate, G4LogicalVolume *pCurrentLogical, const G4String &pName, G4LogicalVolume *pMotherLogical, G4bool pMany, G4int pCopyNo, G4bool pSurfChk=false)
virtual G4double DistanceToIn(const G4ThreeVector &p, const G4ThreeVector &v) const =0
G4LogicalVolume * GetMotherLogical() const
G4int GetNoDaughters() const
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *comments)
G4int GetRegularStructureId() const
G4bool CheckOverlaps(G4int res=1000, G4double tol=0., G4bool verbose=true, G4int maxErr=1)
G4LogicalVolume * GetLogicalVolume() const
virtual G4ThreeVector GetPointOnSurface() const
const G4RotationMatrix * GetRotation() const
void SetCopyNo(G4int CopyNo)
void SetMotherLogical(G4LogicalVolume *pMother)
G4bool IsParameterised() const
virtual G4double DistanceToOut(const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcNorm=false, G4bool *validNorm=0, G4ThreeVector *n=0) const =0
void AddDaughter(G4VPhysicalVolume *p)
void GetReplicationData(EAxis &axis, G4int &nReplicas, G4double &width, G4double &offset, G4bool &consuming) const
G4VSolid * GetSolid() const
static G4RotationMatrix * NewPtrRotMatrix(const G4RotationMatrix &RotMat)