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

#include <G4TwistedTrap.hh>

+ Inheritance diagram for G4TwistedTrap:

Public Member Functions

 G4TwistedTrap (const G4String &pName, G4double pPhiTwist, G4double pDx1, G4double pDx2, G4double pDy, G4double pDz)
 
 G4TwistedTrap (const G4String &pName, G4double pPhiTwist, G4double pDz, G4double pTheta, G4double pPhi, G4double pDy1, G4double pDx1, G4double pDx2, G4double pDy2, G4double pDx3, G4double pDx4, G4double pAlph)
 
virtual ~G4TwistedTrap ()
 
G4double GetY1HalfLength () const
 
G4double GetX1HalfLength () const
 
G4double GetX2HalfLength () const
 
G4double GetY2HalfLength () const
 
G4double GetX3HalfLength () const
 
G4double GetX4HalfLength () const
 
G4double GetZHalfLength () const
 
G4double GetPhiTwist () const
 
G4double GetTiltAngleAlpha () const
 
G4double GetPolarAngleTheta () const
 
G4double GetAzimuthalAnglePhi () const
 
G4GeometryType GetEntityType () const
 
G4VSolidClone () const
 
std::ostream & StreamInfo (std::ostream &os) const
 
 G4TwistedTrap (__void__ &)
 
 G4TwistedTrap (const G4TwistedTrap &rhs)
 
G4TwistedTrapoperator= (const G4TwistedTrap &rhs)
 
- Public Member Functions inherited from G4VTwistedFaceted
 G4VTwistedFaceted (const G4String &pname, G4double PhiTwist, G4double pDz, G4double pTheta, G4double pPhi, G4double pDy1, G4double pDx1, G4double pDx2, G4double pDy2, G4double pDx3, G4double pDx4, G4double pAlph)
 
virtual ~G4VTwistedFaceted ()
 
virtual void ComputeDimensions (G4VPVParameterisation *, const G4int, const G4VPhysicalVolume *)
 
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
 
virtual G4double DistanceToIn (const G4ThreeVector &p, const G4ThreeVector &v) const
 
virtual G4double DistanceToIn (const G4ThreeVector &p) const
 
virtual G4double DistanceToOut (const G4ThreeVector &p, const G4ThreeVector &v, const G4bool calcnorm=false, G4bool *validnorm=nullptr, G4ThreeVector *n=nullptr) const
 
virtual G4double DistanceToOut (const G4ThreeVector &p) const
 
virtual EInside Inside (const G4ThreeVector &p) const
 
virtual G4ThreeVector SurfaceNormal (const G4ThreeVector &p) const
 
G4ThreeVector GetPointOnSurface () const
 
G4ThreeVector GetPointInSolid (G4double z) const
 
virtual G4double GetCubicVolume ()
 
virtual G4double GetSurfaceArea ()
 
virtual void DescribeYourselfTo (G4VGraphicsScene &scene) const
 
virtual G4PolyhedronCreatePolyhedron () const
 
virtual G4PolyhedronGetPolyhedron () const
 
virtual std::ostream & StreamInfo (std::ostream &os) const
 
G4double GetTwistAngle () const
 
G4double GetDx1 () const
 
G4double GetDx2 () const
 
G4double GetDx3 () const
 
G4double GetDx4 () const
 
G4double GetDy1 () const
 
G4double GetDy2 () const
 
G4double GetDz () const
 
G4double GetPhi () const
 
G4double GetTheta () const
 
G4double GetAlpha () const
 
G4double Xcoef (G4double u, G4double phi, G4double ftg) const
 
G4double GetValueA (G4double phi) const
 
G4double GetValueB (G4double phi) const
 
G4double GetValueD (G4double phi) const
 
virtual G4VisExtent GetExtent () const
 
virtual G4GeometryType GetEntityType () const
 
 G4VTwistedFaceted (__void__ &)
 
 G4VTwistedFaceted (const G4VTwistedFaceted &rhs)
 
G4VTwistedFacetedoperator= (const G4VTwistedFaceted &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 G4double GetCubicVolume ()
 
virtual G4double GetSurfaceArea ()
 
virtual G4GeometryType GetEntityType () const =0
 
virtual G4ThreeVector GetPointOnSurface () const
 
virtual G4VSolidClone () const
 
virtual std::ostream & StreamInfo (std::ostream &os) const =0
 
void DumpInfo () const
 
virtual void DescribeYourselfTo (G4VGraphicsScene &scene) const =0
 
virtual G4VisExtent GetExtent () const
 
virtual G4PolyhedronCreatePolyhedron () const
 
virtual G4PolyhedronGetPolyhedron () const
 
virtual const G4VSolidGetConstituentSolid (G4int no) const
 
virtual G4VSolidGetConstituentSolid (G4int no)
 
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
 

Additional Inherited Members

- 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 inherited from G4VTwistedFaceted
G4bool fRebuildPolyhedron = false
 
G4PolyhedronfpPolyhedron = nullptr
 
G4double fCubicVolume = 0.0
 
G4double fSurfaceArea = 0.0
 
- Protected Attributes inherited from G4VSolid
G4double kCarTolerance
 

Detailed Description

Definition at line 60 of file G4TwistedTrap.hh.

Constructor & Destructor Documentation

◆ G4TwistedTrap() [1/4]

G4TwistedTrap::G4TwistedTrap ( const G4String pName,
G4double  pPhiTwist,
G4double  pDx1,
G4double  pDx2,
G4double  pDy,
G4double  pDz 
)

Definition at line 38 of file G4TwistedTrap.cc.

44 : G4VTwistedFaceted( pName, pPhiTwist,pDz,0.,0.,
45 pDy, pDx1, pDx2, pDy, pDx1, pDx2,0. )
46{
47}

◆ G4TwistedTrap() [2/4]

G4TwistedTrap::G4TwistedTrap ( const G4String pName,
G4double  pPhiTwist,
G4double  pDz,
G4double  pTheta,
G4double  pPhi,
G4double  pDy1,
G4double  pDx1,
G4double  pDx2,
G4double  pDy2,
G4double  pDx3,
G4double  pDx4,
G4double  pAlph 
)

Definition at line 49 of file G4TwistedTrap.cc.

62 : G4VTwistedFaceted( pName, pPhiTwist, pDz, pTheta,
63 pPhi, pDy1, pDx1, pDx2, pDy2, pDx3, pDx4, pAlph )
64{
65}

◆ ~G4TwistedTrap()

G4TwistedTrap::~G4TwistedTrap ( )
virtual

Definition at line 79 of file G4TwistedTrap.cc.

80{
81}

◆ G4TwistedTrap() [3/4]

G4TwistedTrap::G4TwistedTrap ( __void__ &  a)

Definition at line 71 of file G4TwistedTrap.cc.

73{
74}

◆ G4TwistedTrap() [4/4]

G4TwistedTrap::G4TwistedTrap ( const G4TwistedTrap rhs)

Definition at line 86 of file G4TwistedTrap.cc.

88{
90}
G4Polyhedron * fpPolyhedron
virtual G4Polyhedron * GetPolyhedron() const

Member Function Documentation

◆ Clone()

G4VSolid * G4TwistedTrap::Clone ( ) const
virtual

Reimplemented from G4VSolid.

Definition at line 153 of file G4TwistedTrap.cc.

154{
155 return new G4TwistedTrap(*this);
156}

◆ GetAzimuthalAnglePhi()

G4double G4TwistedTrap::GetAzimuthalAnglePhi ( ) const
inline

Definition at line 100 of file G4TwistedTrap.hh.

100{ return GetPhi() ; }
G4double GetPhi() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetEntityType()

G4GeometryType G4TwistedTrap::GetEntityType ( ) const
virtual

Reimplemented from G4VTwistedFaceted.

Definition at line 145 of file G4TwistedTrap.cc.

146{
147 return G4String("G4TwistedTrap");
148}

◆ GetPhiTwist()

G4double G4TwistedTrap::GetPhiTwist ( ) const
inline

Definition at line 97 of file G4TwistedTrap.hh.

97{ return GetTwistAngle() ; }
G4double GetTwistAngle() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetPolarAngleTheta()

G4double G4TwistedTrap::GetPolarAngleTheta ( ) const
inline

Definition at line 99 of file G4TwistedTrap.hh.

99{ return GetTheta() ; }
G4double GetTheta() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetTiltAngleAlpha()

G4double G4TwistedTrap::GetTiltAngleAlpha ( ) const
inline

Definition at line 98 of file G4TwistedTrap.hh.

98{ return GetAlpha() ; }
G4double GetAlpha() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetX1HalfLength()

G4double G4TwistedTrap::GetX1HalfLength ( ) const
inline

Definition at line 91 of file G4TwistedTrap.hh.

91{ return GetDx1() ; }
G4double GetDx1() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetX2HalfLength()

G4double G4TwistedTrap::GetX2HalfLength ( ) const
inline

Definition at line 92 of file G4TwistedTrap.hh.

92{ return GetDx2() ; }
G4double GetDx2() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetX3HalfLength()

G4double G4TwistedTrap::GetX3HalfLength ( ) const
inline

Definition at line 94 of file G4TwistedTrap.hh.

94{ return GetDx3() ; }
G4double GetDx3() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetX4HalfLength()

G4double G4TwistedTrap::GetX4HalfLength ( ) const
inline

Definition at line 95 of file G4TwistedTrap.hh.

95{ return GetDx4() ; }
G4double GetDx4() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetY1HalfLength()

G4double G4TwistedTrap::GetY1HalfLength ( ) const
inline

Definition at line 90 of file G4TwistedTrap.hh.

90{ return GetDy1() ; }
G4double GetDy1() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetY2HalfLength()

G4double G4TwistedTrap::GetY2HalfLength ( ) const
inline

Definition at line 93 of file G4TwistedTrap.hh.

93{ return GetDy2() ; }
G4double GetDy2() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ GetZHalfLength()

G4double G4TwistedTrap::GetZHalfLength ( ) const
inline

Definition at line 96 of file G4TwistedTrap.hh.

96{ return GetDz() ; }
G4double GetDz() const

Referenced by G4tgbGeometryDumper::GetSolidParams(), StreamInfo(), and G4GDMLWriteSolids::TwistedtrapWrite().

◆ operator=()

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

Definition at line 95 of file G4TwistedTrap.cc.

96{
97 // Check assignment to self
98 //
99 if (this == &rhs) { return *this; }
100
101 // Copy base class data
102 //
105
106 return *this;
107}
G4VTwistedFaceted & operator=(const G4VTwistedFaceted &rhs)

◆ StreamInfo()

std::ostream & G4TwistedTrap::StreamInfo ( std::ostream &  os) const
virtual

Reimplemented from G4VTwistedFaceted.

Definition at line 112 of file G4TwistedTrap.cc.

113{
114 //
115 // Stream object contents to an output stream
116 //
117 os << "-----------------------------------------------------------\n"
118 << " *** Dump for solid - " << GetName() << " ***\n"
119 << " ===================================================\n"
120 << " Solid type: G4TwistedTrap\n"
121 << " Parameters: \n"
122 << " Twist angle = " << GetPhiTwist()/degree << " deg"
123 << G4endl
124 << " Polar Angle Theta = " << GetPolarAngleTheta()/degree << " deg"
125 << G4endl
126 << " Azimuthal Angle Phi = " << GetAzimuthalAnglePhi()/degree << " deg"
127 << G4endl
128 << " pDy1 = " << GetY1HalfLength()/cm << " cm" << G4endl
129 << " pDx1 = " << GetX1HalfLength()/cm << " cm" << G4endl
130 << " pDx2 = " << GetX2HalfLength()/cm << " cm" << G4endl
131 << " pDy2 = " << GetY2HalfLength()/cm << " cm" << G4endl
132 << " pDx3 = " << GetX3HalfLength()/cm << " cm" << G4endl
133 << " pDx4 = " << GetX4HalfLength()/cm << " cm" << G4endl
134 << " pDz = " << GetZHalfLength()/cm << " cm" << G4endl
135 << " Tilt Angle Alpha = " << GetTiltAngleAlpha()/degree << " deg"
136 << G4endl
137 << "-----------------------------------------------------------\n";
138
139 return os;
140}
#define G4endl
Definition: G4ios.hh:57
G4double GetPolarAngleTheta() const
G4double GetAzimuthalAnglePhi() const
G4double GetTiltAngleAlpha() const
G4double GetZHalfLength() const
G4double GetX1HalfLength() const
G4double GetX2HalfLength() const
G4double GetX3HalfLength() const
G4double GetX4HalfLength() const
G4double GetY2HalfLength() const
G4double GetPhiTwist() const
G4double GetY1HalfLength() const
G4String GetName() const

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