ATLAS Offline Software
Loading...
Searching...
No Matches
SCT_Flange.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
4
5#include "SCT_Flange.h"
6
8
11
12#include "GeoModelKernel/GeoTube.h"
13#include "GeoModelKernel/GeoLogVol.h"
14#include "GeoModelKernel/GeoPhysVol.h"
15#include "GeoModelKernel/Units.h"
16
17
18SCT_Flange::SCT_Flange(const std::string & name, int iLayer,
19 InDetDD::SCT_DetectorManager* detectorManager,
20 SCT_GeometryManager* geometryManager,
21 SCT_MaterialManager* materials)
22 : SCT_SharedComponentFactory(name, detectorManager, geometryManager, materials),
23 m_iLayer(iLayer)
24{
27}
28
29
30void
32{
33 const SCT_BarrelParameters * parameters = m_geometryManager->barrelParameters();
34
35 m_materialName = parameters->flangeMaterial(m_iLayer);
36 m_length = parameters->flangeDeltaZ(m_iLayer);
37 m_radialWidth = parameters->flangeDeltaR(m_iLayer);
38
39 if(parameters->isOldGeometry()) {
40 // Same outer radius as support cylinder
41 m_outerRadius = parameters->supportCylOuterRadius(m_iLayer);
42 }
43 else {
44 // Outer radius is inner radius of support cylinder
45 m_outerRadius = parameters->supportCylInnerRadius(m_iLayer);
46 }
48}
49
50GeoVPhysVol *
52{
53 // Make the flange. A simple tube.
54 const GeoTube * flangeShape = new GeoTube(m_innerRadius, m_outerRadius, 0.5 * m_length);
55 m_material = m_materials->getMaterialForVolume(m_materialName, flangeShape->volume());
56 if(!m_material) {m_material = m_materials->getMaterial(m_materialName);}
57 const GeoLogVol * flangeLog = new GeoLogVol(getName(), flangeShape, m_material);
58
59 GeoPhysVol * flange = new GeoPhysVol(flangeLog);
60
61 return flange;
62}
Dedicated detector manager extending the functionality of the SiDetectorManager with dedicated SCT in...
const std::string & getName() const
SCT_GeometryManager * m_geometryManager
SCT_MaterialManager * m_materials
const GeoMaterial * m_material
Definition SCT_Flange.h:36
std::string m_materialName
Definition SCT_Flange.h:37
SCT_Flange(const std::string &name, int iLayer, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials)
void getParameters()
double m_outerRadius
Definition SCT_Flange.h:39
double m_radialWidth
Definition SCT_Flange.h:41
virtual GeoVPhysVol * build()
double m_length
Definition SCT_Flange.h:40
double m_innerRadius
Definition SCT_Flange.h:38
SCT_SharedComponentFactory(const std::string &name, InDetDD::SCT_DetectorManager *detectorManager, SCT_GeometryManager *geometryManager, SCT_MaterialManager *materials=nullptr)