ATLAS Offline Software
SCT_Hybrid.cxx
Go to the documentation of this file.
1 /*
2  Copyright (C) 2002-2022 CERN for the benefit of the ATLAS collaboration
3 */
4 
6 
8 
11 
12 #include "GeoModelKernel/GeoBox.h"
13 #include "GeoModelKernel/GeoLogVol.h"
14 #include "GeoModelKernel/GeoPhysVol.h"
15 #include "GeoModelKernel/GeoMaterial.h"
16 #include "GeoModelKernel/Units.h"
17 
18 SCT_Hybrid::SCT_Hybrid(const std::string & name,
19  InDetDD::SCT_DetectorManager* detectorManager,
20  SCT_GeometryManager* geometryManage,
21  SCT_MaterialManager* materials)
22  : SCT_SharedComponentFactory(name, detectorManager, geometryManage, materials)
23 {
24  getParameters();
26 }
27 
28 void
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 }
37 
38 GeoVPhysVol *
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 }
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_MaterialManager
Definition: SCT_MaterialManager.h:21
InDetDD::SCT_DetectorManager
Definition: SCT_DetectorManager.h:49
SCT_MaterialManager.h
SCT_BarrelModuleParameters.h
SCT_Hybrid::getParameters
void getParameters()
Definition: SCT_Hybrid.cxx:29
SCT_Hybrid::m_length
double m_length
Definition: SCT_Hybrid.h:37
SCT_Hybrid::SCT_Hybrid
SCT_Hybrid(const std::string &name, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials)
Definition: SCT_Hybrid.cxx:18
SCT_Hybrid::m_width
double m_width
Definition: SCT_Hybrid.h:36
SCT_Hybrid.h
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:195
SCT_SharedComponentFactory::m_physVolume
GeoVPhysVol * m_physVolume
Definition: SCT_ComponentFactory.h:70
SCT_BarrelModuleParameters
Definition: SCT_BarrelModuleParameters.h:12
SCT_MaterialManager::getMaterial
const GeoMaterial * getMaterial(const std::string &materialName)
Definition: SCT_MaterialManager.cxx:51
SCT_SharedComponentFactory
Definition: SCT_ComponentFactory.h:56
physics_parameters.parameters
parameters
Definition: physics_parameters.py:144
SCT_Hybrid::m_material
const GeoMaterial * m_material
Definition: SCT_Hybrid.h:34
SCT_Hybrid::build
virtual GeoVPhysVol * build()
Definition: SCT_Hybrid.cxx:39
SCT_ComponentFactory::getName
const std::string & getName() const
Definition: SCT_ComponentFactory.h:35
SCT_GeometryManager.h
SCT_GeometryManager
Definition: SCT_GeometryManager.h:25