CMS 3D CMS Logo

List of all members | Public Member Functions
DDTrap Class Reference

Interface to a Trapezoid. More...

#include <DDSolid.h>

Inheritance diagram for DDTrap:
DDSolid DDBase< DDName, std::unique_ptr< DDI::Solid > >

Public Member Functions

double alpha1 (void) const
 Angle with respect to the y axis from the centre of the side at y=-pDy1 to the centre at y=+pDy1 of the face at -pDz. More...
 
double alpha2 (void) const
 Angle with respect to the y axis from the centre of the side at y=-pDy2 to the centre at y=+pDy2 of the face at +pDz. More...
 
 DDTrap (const DDSolid &s)
 
 DDTrap (void)=delete
 
double halfZ (void) const
 half of the z-Axis More...
 
double phi (void) const
 Azimuthal angle of the line joining the centres of the faces at -/+pDz. More...
 
double theta (void) const
 Polar angle of the line joining the centres of the faces at -/+pDz. More...
 
double x1 (void) const
 Half-length along x of the side at y=-pDy1 of the face at -pDz. More...
 
double x2 (void) const
 Half-length along x of the side at y=+pDy1 of the face at -pDz. More...
 
double x3 (void) const
 Half-length along x of the side at y=-pDy2 of the face at +pDz. More...
 
double x4 (void) const
 Half-length along x of the side at y=+pDy2 of the face at +pDz. More...
 
double y1 (void) const
 Half-length along y of the face at -pDz. More...
 
double y2 (void) const
 Half-length along y of the face at +pDz. More...
 
- Public Member Functions inherited from DDSolid
 DDSolid (void)
 Uninitialilzed solid reference-object; for further details on reference-objects see documentation of DDLogicalPart. More...
 
 DDSolid (const DDName &name)
 Creates a reference-object to a solid named name. More...
 
const std::vector< double > & parameters (void) const
 Give the parameters of the solid. More...
 
DDSolidShape shape (void) const
 The type of the solid. More...
 
double volume (void) const
 Returns the volume of the given solid (does not work with boolean soids !) More...
 
- Public Member Functions inherited from DDBase< DDName, std::unique_ptr< DDI::Solid > >
void create (const DDName &name, std::unique_ptr< DDI::Solid > vals)
 
void create (const DDName &name)
 
 DDBase ()
 
const DDNameddname () const
 
def_type isDefined () const
 
bool isValid () const
 true, if the wrapped pointer is valid More...
 
const DDNamename () const
 
 operator bool () const
 
bool operator< (const DDBase &b) const
 
bool operator== (const DDBase &b) const
 
bool operator> (const DDBase &b) const
 
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep () const
 
DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep ()
 
std::string toString () const
 
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference val () const
 
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference val ()
 
virtual ~DDBase ()
 

Additional Inherited Members

- Public Types inherited from DDBase< DDName, std::unique_ptr< DDI::Solid > >
using def_type = std::pair< const DDName *, bool >
 
using StoreT = DDI::Singleton< DDI::Store< DDName, std::unique_ptr< DDI::Solid > > >
 
- Static Public Member Functions inherited from DDBase< DDName, std::unique_ptr< DDI::Solid > >
static auto begin ()
 
static auto end ()
 

Detailed Description

Interface to a Trapezoid.

The definition (parameters, local frame) of the Trapezoid is the same than in Geant4.

Definition at line 88 of file DDSolid.h.

Constructor & Destructor Documentation

◆ DDTrap() [1/2]

DDTrap::DDTrap ( const DDSolid s)

Definition at line 127 of file DDSolid.cc.

References ddtrap, Exception, alignCSCRings::s, and AlCaHLTBitMon_QueryRunRegistry::string.

127  : DDSolid(s) {
128  if (s.shape() != DDSolidShape::ddtrap) {
129  std::string ex = "Solid [" + s.name().ns() + ":" + s.name().name() + "] is no DDTrap.\n";
130  ex = ex + "Use a different solid interface!";
131  throw cms::Exception("DDException") << ex;
132  }
133 }
DDSolid(void)
Uninitialilzed solid reference-object; for further details on reference-objects see documentation of ...
Definition: DDSolid.cc:50

◆ DDTrap() [2/2]

DDTrap::DDTrap ( void  )
delete

Member Function Documentation

◆ alpha1()

double DDTrap::alpha1 ( void  ) const

Angle with respect to the y axis from the centre of the side at y=-pDy1 to the centre at y=+pDy1 of the face at -pDz.

Definition at line 147 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdX::checkParametersValidity(), DDDividedTrdY::checkParametersValidity(), DDDividedTrdZ::checkParametersValidity(), HGCalSimHitValidation::defineGeometry(), HcalGeomParameters::loadGeometry(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

147 { return rep().parameters()[6]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ alpha2()

double DDTrap::alpha2 ( void  ) const

Angle with respect to the y axis from the centre of the side at y=-pDy2 to the centre at y=+pDy2 of the face at +pDz.

Definition at line 155 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdX::checkParametersValidity(), DDDividedTrdY::checkParametersValidity(), DDDividedTrdZ::checkParametersValidity(), HcalGeomParameters::loadGeometry(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

155 { return rep().parameters()[10]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ halfZ()

double DDTrap::halfZ ( void  ) const

◆ phi()

double DDTrap::phi ( void  ) const

Azimuthal angle of the line joining the centres of the faces at -/+pDz.

Definition at line 139 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by Particle.Particle::__str__(), DDDividedTrdX::checkParametersValidity(), DDDividedTrdY::checkParametersValidity(), DDDividedTrdZ::checkParametersValidity(), ntupleDataFormat.Track::phiPull(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

139 { return rep().parameters()[2]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ theta()

double DDTrap::theta ( void  ) const

Polar angle of the line joining the centres of the faces at -/+pDz.

Definition at line 137 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdX::checkParametersValidity(), DDDividedTrdY::checkParametersValidity(), DDDividedTrdZ::checkParametersValidity(), DDCoreToDDXMLOutput::solid(), MagGeoBuilderFromDDD::volumeHandle::volumeHandle(), and Tau.Tau::zImpact().

137 { return rep().parameters()[1]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ x1()

double DDTrap::x1 ( void  ) const

◆ x2()

double DDTrap::x2 ( void  ) const

◆ x3()

double DDTrap::x3 ( void  ) const

Half-length along x of the side at y=-pDy2 of the face at +pDz.

Definition at line 151 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdX::checkParametersValidity(), HcalGeomParameters::loadGeometry(), DDDividedTrdY::makeDDLogicalPart(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

151 { return rep().parameters()[8]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ x4()

double DDTrap::x4 ( void  ) const

Half-length along x of the side at y=+pDy2 of the face at +pDz.

Definition at line 153 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdX::checkParametersValidity(), HcalGeomParameters::loadGeometry(), DDDividedTrdY::makeDDLogicalPart(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

153 { return rep().parameters()[9]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65

◆ y1()

double DDTrap::y1 ( void  ) const

◆ y2()

double DDTrap::y2 ( void  ) const

Half-length along y of the face at +pDz.

Definition at line 149 of file DDSolid.cc.

References DDBase< DDName, std::unique_ptr< DDI::Solid > >::rep().

Referenced by DDDividedTrdY::checkParametersValidity(), HcalGeomParameters::loadGeometry(), DDDividedTrdX::makeDDLogicalPart(), DDDividedTrdZ::makeDDLogicalPart(), DDCoreToDDXMLOutput::solid(), and MagGeoBuilderFromDDD::volumeHandle::volumeHandle().

149 { return rep().parameters()[7]; }
const DDI::rep_traits< DDName, std::unique_ptr< DDI::Solid > >::reference rep() const
Definition: DDBase.h:65