ATLAS Offline Software
InnerDetector
InDetDetDescr
SCT_GeoModel
src
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
5
#include "
SCT_GeoModel/SCT_Hybrid.h
"
6
7
#include "
SCT_GeoModel/SCT_MaterialManager.h
"
8
9
#include "
SCT_GeoModel/SCT_GeometryManager.h
"
10
#include "
SCT_GeoModel/SCT_BarrelModuleParameters.h
"
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
();
25
m_physVolume
=
SCT_Hybrid::build
();
26
}
27
28
void
29
SCT_Hybrid::getParameters
()
30
{
31
const
SCT_BarrelModuleParameters
*
parameters
=
m_geometryManager
->
barrelModuleParameters
();
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 *
39
SCT_Hybrid::build
()
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:221
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:40
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
Generated on Thu Nov 7 2024 21:25:30 for ATLAS Offline Software by
1.8.18