ATLAS Offline Software
Public Member Functions | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | Static Private Attributes | List of all members
SCT_Hybrid Class Reference

#include <SCT_Hybrid.h>

Inheritance diagram for SCT_Hybrid:
Collaboration diagram for SCT_Hybrid:

Public Member Functions

 SCT_Hybrid (const std::string &name, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials)
 
const GeoMaterial * material () const
 
double thickness () const
 
double width () const
 
double length () const
 
GeoVPhysVol * getVolume ()
 
const std::string & getName () const
 
std::string intToString (int i) const
 

Protected Member Functions

double epsilon () const
 

Protected Attributes

GeoVPhysVol * m_physVolume
 
InDetDD::SCT_DetectorManagerm_detectorManager
 
SCT_GeometryManagerm_geometryManager
 
SCT_MaterialManagerm_materials
 

Private Member Functions

void getParameters ()
 
virtual GeoVPhysVol * build ()
 

Private Attributes

const GeoMaterial * m_material = nullptr
 
double m_thickness = 0.0
 
double m_width = 0.0
 
double m_length = 0.0
 
std::string m_name
 

Static Private Attributes

static const double s_epsilon = 1.0e-6 * Gaudi::Units::mm
 

Detailed Description

Definition at line 15 of file SCT_Hybrid.h.

Constructor & Destructor Documentation

◆ SCT_Hybrid()

SCT_Hybrid::SCT_Hybrid ( const std::string &  name,
InDetDD::SCT_DetectorManager detectorManager,
SCT_GeometryManager geometryManager,
SCT_MaterialManager materials 
)

Definition at line 18 of file SCT_Hybrid.cxx.

22  : SCT_SharedComponentFactory(name, detectorManager, geometryManage, materials)
23 {
24  getParameters();
26 }

Member Function Documentation

◆ build()

GeoVPhysVol * SCT_Hybrid::build ( )
privatevirtual

Implements SCT_SharedComponentFactory.

Definition at line 39 of file SCT_Hybrid.cxx.

40 {
41  // Build the . Just a simple box.
42  const GeoBox * simpleHybridShape = new GeoBox(0.5*m_thickness,
43  0.5*m_width,
44  0.5*m_length);
45  const GeoLogVol * simpleHybridLog =
46  new GeoLogVol(getName(), simpleHybridShape, m_material);
47  GeoPhysVol * simpleHybrid = new GeoPhysVol(simpleHybridLog);
48 
49  return simpleHybrid;
50 }

◆ epsilon()

double SCT_ComponentFactory::epsilon ( ) const
protectedinherited

Definition at line 38 of file SCT_ComponentFactory.cxx.

39 {
40  return s_epsilon;
41 }

◆ getName()

const std::string& SCT_ComponentFactory::getName ( ) const
inlineinherited

Definition at line 35 of file SCT_ComponentFactory.h.

35 {return m_name;}

◆ getParameters()

void SCT_Hybrid::getParameters ( )
private

Definition at line 29 of file SCT_Hybrid.cxx.

30 {
32  m_material = m_materials->getMaterial(parameters->hybridMaterial());
33  m_thickness = parameters->hybridThickness();
34  m_length = parameters->hybridLength();
35  m_width = parameters->hybridWidth();
36 }

◆ getVolume()

GeoVPhysVol* SCT_SharedComponentFactory::getVolume ( )
inlineinherited

Definition at line 67 of file SCT_ComponentFactory.h.

67 {return m_physVolume;}

◆ intToString()

std::string SCT_ComponentFactory::intToString ( int  i) const
inherited

Definition at line 30 of file SCT_ComponentFactory.cxx.

31 {
32  std::ostringstream str;
33  str << i;
34  return str.str();
35 }

◆ length()

double SCT_Hybrid::length ( ) const
inline

Definition at line 28 of file SCT_Hybrid.h.

28 {return m_length;}

◆ material()

const GeoMaterial* SCT_Hybrid::material ( ) const
inline

Definition at line 25 of file SCT_Hybrid.h.

25 {return m_material;}

◆ thickness()

double SCT_Hybrid::thickness ( ) const
inline

Definition at line 26 of file SCT_Hybrid.h.

26 {return m_thickness;}

◆ width()

double SCT_Hybrid::width ( ) const
inline

Definition at line 27 of file SCT_Hybrid.h.

27 {return m_width;}

Member Data Documentation

◆ m_detectorManager

InDetDD::SCT_DetectorManager* SCT_ComponentFactory::m_detectorManager
protectedinherited

Definition at line 41 of file SCT_ComponentFactory.h.

◆ m_geometryManager

SCT_GeometryManager* SCT_ComponentFactory::m_geometryManager
protectedinherited

Definition at line 42 of file SCT_ComponentFactory.h.

◆ m_length

double SCT_Hybrid::m_length = 0.0
private

Definition at line 37 of file SCT_Hybrid.h.

◆ m_material

const GeoMaterial* SCT_Hybrid::m_material = nullptr
private

Definition at line 34 of file SCT_Hybrid.h.

◆ m_materials

SCT_MaterialManager* SCT_ComponentFactory::m_materials
protectedinherited

Definition at line 43 of file SCT_ComponentFactory.h.

◆ m_name

std::string SCT_ComponentFactory::m_name
privateinherited

Definition at line 49 of file SCT_ComponentFactory.h.

◆ m_physVolume

GeoVPhysVol* SCT_SharedComponentFactory::m_physVolume
protectedinherited

Definition at line 70 of file SCT_ComponentFactory.h.

◆ m_thickness

double SCT_Hybrid::m_thickness = 0.0
private

Definition at line 35 of file SCT_Hybrid.h.

◆ m_width

double SCT_Hybrid::m_width = 0.0
private

Definition at line 36 of file SCT_Hybrid.h.

◆ s_epsilon

const double SCT_ComponentFactory::s_epsilon = 1.0e-6 * Gaudi::Units::mm
staticprivateinherited

Definition at line 50 of file SCT_ComponentFactory.h.


The documentation for this class was generated from the following files:
SCT_Hybrid::m_thickness
double m_thickness
Definition: SCT_Hybrid.h:35
SCT_ComponentFactory::m_geometryManager
SCT_GeometryManager * m_geometryManager
Definition: SCT_ComponentFactory.h:42
SCT_ComponentFactory::m_name
std::string m_name
Definition: SCT_ComponentFactory.h:49
SCT_Hybrid::getParameters
void getParameters()
Definition: SCT_Hybrid.cxx:29
SCT_Hybrid::m_length
double m_length
Definition: SCT_Hybrid.h:37
lumiFormat.i
int i
Definition: lumiFormat.py:85
SCT_Hybrid::m_width
double m_width
Definition: SCT_Hybrid.h:36
SCT_ComponentFactory::s_epsilon
static const double s_epsilon
Definition: SCT_ComponentFactory.h:50
SCT_GeometryManager::barrelModuleParameters
const SCT_BarrelModuleParameters * barrelModuleParameters() const
Definition: SCT_GeometryManager.cxx:84
SCT_ComponentFactory::m_materials
SCT_MaterialManager * m_materials
Definition: SCT_ComponentFactory.h:43
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:221
SCT_SharedComponentFactory::m_physVolume
GeoVPhysVol * m_physVolume
Definition: SCT_ComponentFactory.h:70
SCT_SharedComponentFactory::SCT_SharedComponentFactory
SCT_SharedComponentFactory(const std::string &name, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials=nullptr)
Definition: SCT_ComponentFactory.h:59
SCT_BarrelModuleParameters
Definition: SCT_BarrelModuleParameters.h:12
SCT_MaterialManager::getMaterial
const GeoMaterial * getMaterial(const std::string &materialName)
Definition: SCT_MaterialManager.cxx:40
python.CaloScaleNoiseConfig.str
str
Definition: CaloScaleNoiseConfig.py:78
physics_parameters.parameters
parameters
Definition: physics_parameters.py:144
SCT_Hybrid::m_material
const GeoMaterial * m_material
Definition: SCT_Hybrid.h:34
str
Definition: BTagTrackIpAccessor.cxx:11
SCT_Hybrid::build
virtual GeoVPhysVol * build()
Definition: SCT_Hybrid.cxx:39
SCT_ComponentFactory::getName
const std::string & getName() const
Definition: SCT_ComponentFactory.h:35