46 #define G4MT_rot ((subInstanceManager.offset[instanceID]).frot)
47 #define G4MT_trans ((subInstanceManager.offset[instanceID]).ftrans)
48 #define G4MT_pvdata (subInstanceManager.offset[instanceID])
58 fname(pName), flmother(0)
77 : flogical(0), fname(
""), flmother(0), pvdata(0)
const G4RotationMatrix * GetFrameRotation() const
CLHEP::Hep3Vector G4ThreeVector
static void Register(G4VPhysicalVolume *pSolid)
void TerminateWorker(G4VPhysicalVolume *pMasterObject)
G4VPhysicalVolume(G4RotationMatrix *pRot, const G4ThreeVector &tlate, const G4String &pName, G4LogicalVolume *pLogical, G4VPhysicalVolume *pMother)
G4int CreateSubInstance()
void SetTranslation(const G4ThreeVector &v)
const G4ThreeVector & GetTranslation() const
static void DeRegister(G4VPhysicalVolume *pSolid)
virtual G4int GetMultiplicity() const
virtual G4bool CheckOverlaps(G4int res=1000, G4double tol=0., G4bool verbose=true, G4int errMax=1)
static const G4PVManager & GetSubInstanceManager()
G4ThreeVector GetFrameTranslation() const
G4RotationMatrix * GetObjectRotation() const
G4RotationMatrix GetObjectRotationValue() const
virtual ~G4VPhysicalVolume()
void SlaveCopySubInstanceArray()
void SetRotation(G4RotationMatrix *)
const G4RotationMatrix * GetRotation() const
void InitialiseWorker(G4VPhysicalVolume *pMasterObject, G4RotationMatrix *pRot, const G4ThreeVector &tlate)
G4ThreeVector GetObjectTranslation() const
static G4GEOM_DLL G4PVManager subInstanceManager
HepRotation inverse() const