ATLAS Offline Software
SCT_FSIScorpion.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 
19  InDetDD::SCT_DetectorManager* detectorManager,
20  SCT_GeometryManager* geometryManager,
21  SCT_MaterialManager* materials)
22  : SCT_SharedComponentFactory(name, detectorManager, geometryManager, materials)
23 {
24  getParameters();
26 }
27 
28 
29 void
31 {
33  m_materialName = parameters->fsiScorpionMaterial();
34  m_radialWidth = parameters->fsiScorpionRadialWidth();
35  m_rPhiWidth = parameters->fsiScorpionRPhiWidth();
36  m_length = parameters->fsiScorpionLength();
37 }
38 
39 GeoVPhysVol *
41 {
42 
43  // Build the barrel FSI scorpion. Just a simple box.
44  // Length is in z-direction.
45  const GeoBox * scorpionShape = new GeoBox(0.5*m_radialWidth, 0.5*m_rPhiWidth, 0.5*m_length);
46  m_material = m_materials->getMaterialForVolume(m_materialName, scorpionShape->volume());
47  const GeoLogVol *scorpionLog = new GeoLogVol(getName(), scorpionShape, m_material);
48  GeoPhysVol * scorpion = new GeoPhysVol(scorpionLog);
49 
50  return scorpion;
51 }
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_FSIScorpion::m_materialName
std::string m_materialName
Definition: SCT_FSIScorpion.h:35
SCT_FSIScorpion::m_radialWidth
double m_radialWidth
Definition: SCT_FSIScorpion.h:36
SCT_FSIScorpion::m_material
const GeoMaterial * m_material
Definition: SCT_FSIScorpion.h:34
SCT_FSIScorpion::m_rPhiWidth
double m_rPhiWidth
Definition: SCT_FSIScorpion.h:37
SCT_GeometryManager::barrelParameters
const SCT_BarrelParameters * barrelParameters() const
Definition: SCT_GeometryManager.cxx:78
SCT_FSIScorpion.h
SCT_FSIScorpion::SCT_FSIScorpion
SCT_FSIScorpion(const std::string &name, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials)
Definition: SCT_FSIScorpion.cxx:18
SCT_MaterialManager::getMaterialForVolume
const GeoMaterial * getMaterialForVolume(const std::string &materialName, double volume)
Definition: SCT_MaterialManager.cxx:61
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_FSIScorpion::build
virtual GeoVPhysVol * build()
Definition: SCT_FSIScorpion.cxx:40
SCT_BarrelParameters
Definition: SCT_BarrelParameters.h:12
SCT_BarrelParameters.h
SCT_SharedComponentFactory
Definition: SCT_ComponentFactory.h:56
physics_parameters.parameters
parameters
Definition: physics_parameters.py:144
SCT_FSIScorpion::getParameters
void getParameters()
Definition: SCT_FSIScorpion.cxx:30
SCT_ComponentFactory::getName
const std::string & getName() const
Definition: SCT_ComponentFactory.h:35
SCT_FSIScorpion::m_length
double m_length
Definition: SCT_FSIScorpion.h:38
SCT_GeometryManager.h
SCT_GeometryManager
Definition: SCT_GeometryManager.h:25