7#include <Acts/Geometry/BlueprintNode.hpp>
8#include <Acts/Geometry/StaticBlueprintNode.hpp>
9#include <Acts/Geometry/CylinderVolumeBounds.hpp>
10#include <Acts/Geometry/ContainerBlueprintNode.hpp>
11#include <Acts/Geometry/MultiWireVolumeBuilder.hpp>
12#include <Acts/Surfaces/TrapezoidBounds.hpp>
13#include <Acts/Geometry/MaterialDesignatorBlueprintNode.hpp>
14#include <Acts/Geometry/GeometryIdentifierBlueprintNode.hpp>
15#include <Acts/Geometry/VolumeAttachmentStrategy.hpp>
16#include <Acts/Geometry/VolumeResizeStrategy.hpp>
17#include <Acts/Geometry/TrackingVolume.hpp>
18#include <Acts/Geometry/TrapezoidVolumeBounds.hpp>
19#include <Acts/Geometry/CuboidVolumeBounds.hpp>
20#include <Acts/Geometry/DiamondVolumeBounds.hpp>
21#include <Acts/Surfaces/PlaneSurface.hpp>
22#include <Acts/Surfaces/CylinderSurface.hpp>
23#include <Acts/Surfaces/DiscSurface.hpp>
24#include <Acts/Surfaces/RadialBounds.hpp>
25#include <ActsPlugins/GeoModel/GeoModelMaterialConverter.hpp>
26#include <Acts/Visualization/ObjVisualization3D.hpp>
27#include <Acts/Visualization/GeometryView3D.hpp>
28#include <Acts/Surfaces/LineBounds.hpp>
29#include <Acts/Material/HomogeneousSurfaceMaterial.hpp>
30#include <Acts/Material/ProtoSurfaceMaterial.hpp>
31#include <Acts/Surfaces/RectangleBounds.hpp>
38#include "GeoModelValidation/GeoMaterialHelper.h"
40using namespace Acts::UnitLiterals;
45 constexpr std::size_t s_muonBarrelId = 80;
46 constexpr std::size_t s_muonEndcapAId = 81;
47 constexpr std::size_t s_muonEndcapCId = 82;
48 constexpr std::size_t s_muonEndcapMiddleAId = 83;
49 constexpr std::size_t s_muonEndcapMiddleCId = 84;
52 void configureMaterialFaces(
53 Acts::Experimental::MaterialDesignatorBlueprintNode&
node,
54 const Acts::VolumeBounds& bounds,
55 std::shared_ptr<const Acts::ISurfaceMaterial> material){
57 switch (bounds.type()) {
58 case Acts::VolumeBounds::BoundsType::eCuboid: {
60 Acts::CuboidVolumeBounds::Face::NegativeZFace, material);
62 Acts::CuboidVolumeBounds::Face::PositiveZFace, material);
65 case Acts::VolumeBounds::BoundsType::eTrapezoid: {
67 Acts::TrapezoidVolumeBounds::Face::NegativeZFaceXY, material);
69 Acts::TrapezoidVolumeBounds::Face::PositiveZFaceXY, material);
72 case Acts::VolumeBounds::BoundsType::eDiamond: {
74 Acts::DiamondVolumeBounds::Face::NegativeZFaceXY, material);
76 Acts::DiamondVolumeBounds::Face::PositiveZFaceXY, material);
81 "Unsupported volume bounds for material configuration");
92 return StatusCode::SUCCESS;
99EnvelopeSet_t barrelStations, endcapOuterAStations, endcapOuterCStations,
100 endcapMiddleAStations, endcapMiddleCStations;
103 elements =
m_detMgr->getAllSectors();
105 elements =
m_detMgr->getAllChambers();
108std::visit([&](
auto& elems) {
109 using SetType = std::decay_t<
decltype(elems)>;
112 SetType
barrel, endcapA, endcapC, endcapMiddleA, endcapMiddleC;
114 for (
const auto& element : elems) {
116 {StIdx::BI, StIdx::BM, StIdx::BO, StIdx::BE, StIdx::EE, StIdx::EI},
118 barrel.push_back(element);
120 endcapA.push_back(element);
122 endcapC.push_back(element);
124 endcapMiddleA.push_back(element);
126 endcapMiddleC.push_back(element);
129 <<
" not assigned to any station!");
134 barrelStations = std::move(
barrel);
135 endcapOuterAStations = std::move(endcapA);
136 endcapOuterCStations = std::move(endcapC);
137 endcapMiddleAStations = std::move(endcapMiddleA);
138 endcapMiddleCStations = std::move(endcapMiddleC);
142auto muonNode = std::make_shared<Acts::Experimental::CylinderContainerBlueprintNode>(
"MuonNode", Acts::AxisDirection::AxisZ);
144Acts::VolumeBoundFactory boundsFactory{};
145auto barrelNode =
buildMuonNode(gctx, barrelStations,
"BI_BM_BO_EE_EI", Acts::GeometryIdentifier().withVolume(s_muonBarrelId), boundsFactory, {ChIdx::BIS, ChIdx::BML, ChIdx::BOL,
146 ChIdx::EIS, ChIdx::EIL});
147auto endcapANode =
buildMuonNode(gctx, endcapOuterAStations,
"EO_A", Acts::GeometryIdentifier().withVolume(s_muonEndcapAId), boundsFactory);
148auto endcapCNode =
buildMuonNode(gctx, endcapOuterCStations,
"EO_C", Acts::GeometryIdentifier().withVolume(s_muonEndcapCId), boundsFactory);
149auto endcapMiddleANode =
buildMuonNode(gctx, endcapMiddleAStations,
"EM_A", Acts::GeometryIdentifier().withVolume(s_muonEndcapMiddleAId), boundsFactory, {ChIdx::EML, ChIdx::EMS});
150auto endcapMiddleCNode =
buildMuonNode(gctx, endcapMiddleCStations,
"EM_C", Acts::GeometryIdentifier().withVolume(s_muonEndcapMiddleCId), boundsFactory, {ChIdx::EML, ChIdx::EMS});
154 barrelNode->addChild(std::move(childNode));
156muonNode->addChild(std::move(barrelNode));
157muonNode->addChild(std::move(endcapANode));
158muonNode->addChild(std::move(endcapCNode));
159muonNode->addChild(std::move(endcapMiddleANode));
160muonNode->addChild(std::move(endcapMiddleCNode));
166std::shared_ptr<Acts::Experimental::StaticBlueprintNode>
169 const std::string& name,
170 const Acts::GeometryIdentifier&
id,
171 Acts::VolumeBoundFactory& boundsFactory,
172 const std::vector<ChIdx>& passiveStationIds)
const {
175 std::vector<std::string> stationNames;
177 std::vector<staticNodePtr> nodes;
179 std::vector<materialNodePtr> materialNodes;
181 double innerRadius{0.0};
182 double outerRadius{std::numeric_limits<double>::lowest()};
183 double maxZ{std::numeric_limits<double>::lowest()};
184 double minZ{std::numeric_limits<double>::max()};
186 std::vector<std::shared_ptr<Acts::Surface>> passiveSurfaces;
188 std::visit([&](
const auto& elems){
190 using SetType = std::decay_t<
decltype(elems)>;
191 std::unordered_map<unsigned int, SetType> elementsPerStation;
193 for(
const auto& element : elems){
194 std::unique_ptr<Acts::TrackingVolume> vol{};
196 vol = std::make_unique<Acts::TrackingVolume>(*element->boundingVolume(*context),
197 element->identString());
199 vol = std::make_unique<Acts::TrackingVolume>(element->localToGlobalTransform(*context),
201 element->identString());
204 Acts::GeometryIdentifier chId =
id.withLayer(chamberId++);
205 vol->assignGeometryId(chId);
208 std::pair<std::vector<blueprintNodePtr>,std::vector<surfacePtr>> innerStructure =
getSensitiveElements(*context, *element, chId, boundsFactory);
209 for(
auto& surface: innerStructure.second){
210 vol->addSurface(surface);
214 for(
const auto& surface: vol->volumeBounds().orientedSurfaces(vol->localToGlobalTransform(gctx))) {
215 const auto& surfaceRepr = (*surface.surface);
216 const Acts::Polyhedron& polyhedron = surfaceRepr.polyhedronRepresentation(gctx);
219 maxZ = std::max(maxZ, center.z());
220 minZ = std::min(minZ, center.z());
224 outerRadius = std::max(outerRadius, vertex.perp());
230 const bool isSingleMdt =
231 (element->readoutEles().size() == 1 &&
237 auto matNode = std::dynamic_pointer_cast<Acts::Experimental::MaterialDesignatorBlueprintNode>(innerStructure.first.front());
238 materialNode = std::move(matNode);
241 materialNode = std::make_shared<Acts::Experimental::MaterialDesignatorBlueprintNode>(element->identString() +
"_MaterialNode");
242 configureMaterialFaces(*materialNode, vol->volumeBounds(),
getActiveMaterial(*element));
243 node = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(vol));
244 for (
auto& childNode : innerStructure.first) {
245 auto staticNode = std::dynamic_pointer_cast<Acts::Experimental::StaticBlueprintNode>(childNode);
247 node->addChild(std::move(staticNode));
250 materialNode->addChild(
node);
251 innerStructure.first.clear();
256 materialNodes.push_back(std::move(materialNode));
259 if(!Acts::rangeContainsValue(passiveStationIds, element->chamberIndex())){
264 elementsPerStation[regionChamberHash(detIdx, element->chamberIndex())].push_back(element);
271 double halfLengthZ = 0.5 * std::abs(maxZ - minZ);
272 ATH_MSG_DEBUG(
"Inner radius: " << innerRadius<<
", outer radius: " << outerRadius
273 <<
", max Z: " << maxZ<<
", min Z: " << minZ<<
", half length Z: " << halfLengthZ);
277 auto bounds = boundsFactory.makeBounds<Acts::CylinderVolumeBounds>(innerRadius, outerRadius, halfLengthZ);
278 auto volume = std::make_unique<Acts::TrackingVolume>(trf, bounds, name);
279 volume->assignGeometryId(
id);
282 std::ranges::for_each(passiveSurfaces, [&volume](
auto& surf){
283 volume->addSurface(surf);
286 auto muonNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(volume));
287 ATH_MSG_DEBUG(
"There are " << materialNodes.size() <<
" nodes");
289 std::ranges::for_each(materialNodes, [&muonNode](
const auto&
node) {
290 muonNode->addChild(std::move(
node));
299 const Acts::GeometryIdentifier& chId,
300 Acts::VolumeBoundFactory& boundsFactory)
const
301 requires(std::is_same_v<T, MuonGMR4::Chamber> || std::is_same_v<T, MuonGMR4::SpectrometerSector>){
303 std::vector<blueprintNodePtr> readoutVolumes;
304 std::vector<surfacePtr> readoutSurfaces;
305 Acts::GeometryIdentifier::Value mdtId{1};
309 std::vector<surfacePtr> detSurfaces = readoutEle->getSurfaces();
310 switch(readoutEle->detectorType()){
315 std::unique_ptr<ActsTrk::VolumePlacement> placement{};
318 Acts::Experimental::MultiWireVolumeBuilder::Config mwCfg;
319 mwCfg.name =
m_detMgr->idHelperSvc()->toStringDetEl(mdtReadoutEle->identify());
320 mwCfg.mlSurfaces = detSurfaces;
321 mwCfg.transform = readoutEle->localToGlobalTransform(gctx);
324 std::shared_ptr<Acts::Experimental::MaterialDesignatorBlueprintNode> mdtMaterialNode;
328 if(
isBIS78(readoutEle) && mdtReadoutEle->multilayer() == 2){
332 std::vector<double> tubeLengths;
333 tubeLengths.reserve(mdtReadoutEle->numTubesInLay());
334 for(std::size_t tube = 1; tube < mdtReadoutEle->numTubesInLay(); ++tube){
336 const auto& surface = mdtReadoutEle->surface(tubeHash);
337 const auto& lBounds =
static_cast<const Acts::LineBounds&
>(surface.bounds());
338 using BoundEnum = Acts::LineBounds::BoundValues;
339 const double tubeLength = 2.*lBounds.get(BoundEnum::eHalfLengthZ);
342 auto [minX,maxX] = std::ranges::minmax_element(tubeLengths);
343 int nSmallTubes = std::count_if(tubeLengths.begin(), tubeLengths.end(), [minX](
double length){
344 return std::abs(*minX-length) < Acts::s_epsilon;
348 constexpr double extraMargin = 1._cm;
349 double y2 = (nSmallTubes+1.)*parameters.tubePitch;
350 double y1 = 2.*parameters.halfY + extraMargin - y2;
352 placement = std::make_unique<ActsTrk::VolumePlacement>(*readoutEle,
356 mwCfg.bounds = boundsFactory.makeBounds<Acts::DiamondVolumeBounds>(0.5*(*maxX), 0.5*(*maxX), 0.5*(*minX),
357 y1, y2, parameters.halfHeight);
361 placement = std::make_unique<ActsTrk::VolumePlacement>(*readoutEle);
364 if(std::abs(parameters.shortHalfX - parameters.longHalfX) < Acts::s_epsilon){
365 mwCfg.bounds = boundsFactory.makeBounds<Acts::CuboidVolumeBounds>(parameters.shortHalfX,
367 parameters.halfHeight);
369 mwCfg.bounds = boundsFactory.makeBounds<Acts::TrapezoidVolumeBounds>(parameters.shortHalfX,
370 parameters.longHalfX,
372 parameters.halfHeight);
375 mwCfg.alignablePlacement = placement.get();
377 element.addPlacement(std::move(placement));
379 mwCfg.binning = {{{Acts::AxisDirection::AxisY, Acts::AxisBoundaryType::Bound,
382 static_cast<std::size_t
>(std::lround(2 * parameters.halfY / parameters.tubePitch))}, 2u},
383 {{Acts::AxisDirection::AxisZ, Acts::AxisBoundaryType::Bound,
384 -parameters.halfHeight,
385 parameters.halfHeight,
386 static_cast<std::size_t
>(std::lround(2 * parameters.halfHeight / parameters.tubePitch))}, 1u}};
387 Acts::Experimental::MultiWireVolumeBuilder mdtBuilder{mwCfg};
388 std::unique_ptr<Acts::TrackingVolume> mdtVolume = mdtBuilder.buildVolume();
390 mdtVolume->assignGeometryId(chId.withExtra(mdtId++));
393 if(element.readoutEles().size() == 1){
395 mdtMaterialNode = std::make_shared<Acts::Experimental::MaterialDesignatorBlueprintNode>(element.identString() +
"_MaterialNode");
396 configureMaterialFaces(*mdtMaterialNode, mdtVolume->volumeBounds(),
getActiveMaterial(element));
397 auto staticNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(mdtVolume));
398 mdtMaterialNode->addChild(std::move(staticNode));
399 readoutVolumes.push_back(std::move(mdtMaterialNode));
402 auto mdtNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(mdtVolume));
403 mdtNode->setNavigationPolicyFactory(mdtBuilder.createNavigationPolicyFactory());
404 readoutVolumes.push_back(std::move(mdtNode));
413 readoutSurfaces.insert(readoutSurfaces.end(), std::make_move_iterator(detSurfaces.begin()),
414 std::make_move_iterator(detSurfaces.end()));
425 return std::make_pair(std::move(readoutVolumes), std::move(readoutSurfaces));
435template<
typename ElementSet_t>
436std::vector<std::shared_ptr<Acts::Surface>>
438 const Acts::GeometryContext& gctx,
439 const std::unordered_map<unsigned int, ElementSet_t>& elementsPerStation)
const {
446 constexpr double margin{4._mm};
448 std::vector<std::shared_ptr<Acts::Surface>> surfaces;
449 surfaces.reserve(elementsPerStation.size());
450 LayIdx layIdx = LayIdx::LayerIndexMax;
451 DetIdx detIdx = DetIdx::DetectorRegionIndexMax;
459 switch (readoutEle->detectorType()) {
461 const auto* techEle =
463 if (techEle->multilayer() == 2) {
469 const auto* techEle =
471 if (techEle->doubletZ() == 2) {
479 return isBIS78(readoutEle) && reject;
482 for(
const auto& [hash, elements] : elementsPerStation){
489 double maxZ{std::numeric_limits<double>::lowest()};
490 double minZ{std::numeric_limits<double>::max()};
491 double rMin{std::numeric_limits<double>::max()};
492 double rMax{std::numeric_limits<double>::lowest()};
494 for(
const auto& el : elements){
496 if(rejectBIS78(el->readoutEles().front())){
500 const auto& bounds = el->bounds();
501 for(
const auto& surface : bounds->orientedSurfaces(locToGlobal)){
502 const auto& surfaceRepr = (*surface.surface);
504 rMin = std::min(rMin, center.perp());
505 minZ = std::min(minZ, center.z());
506 maxZ = std::max(maxZ, center.z());
507 rMax = std::max(rMax, center.perp());
511 double halfZ = 0.5*std::abs(maxZ-minZ);
516 const auto& testCh = elements.front();
517 int8_t side = testCh->side();
518 switch (testCh->chamberIndex()) {
522 side > 0 ? zShift = minZ - margin : zShift = maxZ + margin;
524 auto surface = Acts::Surface::makeShared<Acts::DiscSurface>(trf, std::make_shared<Acts::RadialBounds>(0., rMax));
527 surfaces.push_back(surface);
535 if(testCh->chamberIndex() == ChIdx::EIL){
538 side > 0 ? zShift = maxZ + margin : zShift = minZ - margin;
540 auto surface = Acts::Surface::makeShared<Acts::DiscSurface>(trf,
541 std::make_shared<Acts::RadialBounds>(0., rMax));
544 surfaces.push_back(surface);
550 auto surface = Acts::Surface::makeShared<Acts::CylinderSurface>(trf,
551 std::make_shared<Acts::CylinderBounds>(rMin - margin, halfZ));
554 surfaces.push_back(surface);
557 THROW_EXCEPTION(
"No implementation of passive material surface for this station!!!! - sorry :) ");
559 ATH_MSG_VERBOSE(
"Putting passive material surface for station " <<
layerName(layIdx) <<
"/ "<<
regionName(detIdx) <<
": minZ = " << minZ <<
", maxZ = " << maxZ<<
"and radius "<< rMax);
562 if(msgLvl(MSG::VERBOSE)){
563 std::stringstream stream{};
564 for(
const auto& surf : surfaces){
565 stream<<
" at position : "<<
Amg::toString(surf->center(gctx))
566 <<
"with bounds "<< surf->bounds()<<std::endl;
569 <<
" surfaces for passive material description : "<<std::endl<<stream.str());
576std::shared_ptr<const Acts::ISurfaceMaterial>
578 requires(std::is_same_v<T, MuonGMR4::Chamber> ||
579 std::is_same_v<T, MuonGMR4::SpectrometerSector>) {
582 return std::make_shared<Acts::HomogeneousSurfaceMaterial>(Acts::MaterialSlab::Nothing());
585 const float thickness = element.halfZ();
586 PVConstLink parentVolume = element.readoutEles().front()->getMaterialGeom()->getParent();
587 GeoModelTools::GeoMaterialHelper geoMaterialHelper;
588 std::pair<GeoModelTools::GeoMaterialPtr, double> geoMaterials = geoMaterialHelper.collectMaterial(parentVolume);
590 const Acts::Material aMat = ActsPlugins::GeoModel::geoMaterialConverter(*geoMaterials.first);
591 Acts::MaterialSlab slab{aMat, thickness};
592 std::shared_ptr<Acts::HomogeneousSurfaceMaterial> material = std::make_shared<Acts::HomogeneousSurfaceMaterial>(slab);
593 material->scale(0.5);
601 const std::vector<StIdx>& stationIndex,
603 requires(std::is_same_v<T, MuonGMR4::Chamber> ||
604 std::is_same_v<T, MuonGMR4::SpectrometerSector>) {
608 return etaSignCorrect &&
609 Acts::rangeContainsValue(stationIndex,
toStationIndex(element.chamberIndex()));
613std::shared_ptr<Acts::ISurfaceMaterial>
615 const std::size_t nBins1,
616 const std::size_t nBins2)
const {
617 if (nBins1 == 0 || nBins2 == 0) {
619 <<
" as one of the bin dimensions is zero. nBins1: "<<nBins1<<
", nBins2: "<<nBins2);
622 if (nBins1 == 1 && nBins1 == nBins2) {
623 return std::make_shared<Acts::HomogeneousSurfaceMaterial>();
626 std::vector<Acts::DirectedProtoAxis> pmBinning = {};
628 switch (bounds.type()) {
629 using enum Acts::SurfaceBounds::BoundsType;
631 pmBinning = {{Acts::AxisDirection::AxisZ, Acts::AxisBoundaryType::Bound, nBins1},
632 {Acts::AxisDirection::AxisPhi, Acts::AxisBoundaryType::Bound, nBins2}};
635 pmBinning = {{Acts::AxisDirection::AxisR, Acts::AxisBoundaryType::Bound, nBins1},
636 {Acts::AxisDirection::AxisPhi, Acts::AxisBoundaryType::Bound, nBins2}};
643 return std::make_shared<Acts::ProtoGridSurfaceMaterial>(pmBinning);
645std::pair<std::size_t, std::size_t>
669 return std::make_pair(0ul, 0ul);
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
virtual DetectorType detectorType() const =0
Returns the detector element type.
Gaudi::Property< std::size_t > m_nPhiBinsEM1
Number of bins in phi direction on the disc before the middle big wheel.
BluePrintSurfPairs_t getSensitiveElements(const ActsTrk::GeometryContext &gctx, const T &element, const Acts::GeometryIdentifier &chId, Acts::VolumeBoundFactory &boundsFactory) const
Get the chamber's sensitive elements.
Gaudi::Property< std::size_t > m_nZBinsBI
Number of bins in Z direction on the BI cylinder surface.
Gaudi::Property< std::size_t > m_nZBinsBM
Number of bins in Z direction on the BM cylinder surface.
std::shared_ptr< Acts::Experimental::BlueprintNode > buildBlueprintNode(const Acts::GeometryContext &gctx, std::shared_ptr< Acts::Experimental::BlueprintNode > &&childNode) override
Build the Muon Blueprint Node.
staticNodePtr buildMuonNode(const Acts::GeometryContext &gctx, const EnvelopeSet_t &elements, const std::string &name, const Acts::GeometryIdentifier &id, Acts::VolumeBoundFactory &boundsFactory, const std::vector< ChIdx > &passiveStationIds={}) const
Build subnodes for the muon system node.
Gaudi::Property< std::size_t > m_nPhiBinsBI
Number of bins in phi direction on the BI cylinder surface.
std::shared_ptr< Acts::ISurfaceMaterial > preparePassiveMaterial(const Acts::SurfaceBounds &bounds, const std::size_t nBins1, const std::size_t nBins2) const
Prepare a binned material which is associated to the surface.
Gaudi::Property< std::size_t > m_nPhiBinsEI1
Number of bins in phi direction on the disc before the NSW.
bool isElementInTheStation(const T &element, const std::vector< StIdx > &stationNames, const EndcapSide side) const
Check if the chamber is in this node.
Gaudi::Property< bool > m_buildPassiveVolumes
Flag to construct the passive material surfaces.
std::vector< surfacePtr > getPassiveMaterialSurfaces(const Acts::GeometryContext &gctx, const std::unordered_map< unsigned int, ElementSet_t > &elementsPerStation) const
Construct and return the surfaces for the passive material description (e.g cylinders for barrel/ dis...
Muon::MuonStationIndex::DetectorRegionIndex DetIdx
Abrivatin for the detector region index.
Gaudi::Property< std::size_t > m_nPhiBinsEM2
Number of bins in phi direction on the disc after the NSW.
Gaudi::Property< bool > m_alignableVolumes
Flag to control if the volumes should be alignable or not.
Gaudi::Property< bool > m_useSectors
Flag to control if we want to build the muon node from sectors or chambers.
std::pair< std::size_t, std::size_t > getMaterialBins(const Muon::MuonStationIndex::ChIndex chIdx) const
std::pair< std::vector< blueprintNodePtr >, std::vector< surfacePtr > > BluePrintSurfPairs_t
Abrivate the vector pair of blue print nodes and associated active surfaces.
std::variant< MuonChamberSet, MuonSectorSet > EnvelopeSet_t
Hide the flexibility to build the tracking geometry from sectors or chambers behind a variant.
Gaudi::Property< std::size_t > m_nPhiBinsEI2
Number of bins in phi direction on the disc after the NSW.
const MuonGMR4::MuonDetectorManager * m_detMgr
the Detector manager
Gaudi::Property< std::size_t > m_nRBinsEI1
Number of bins in R direction on the disc before the NSW.
Gaudi::Property< std::size_t > m_nRBinsEM1
Number of bins in R direction on the disc before the middle big wheel.
std::shared_ptr< Acts::Experimental::StaticBlueprintNode > staticNodePtr
Abrivation of the blue print node pointer.
Gaudi::Property< std::size_t > m_nRBinsEM2
Number of bins in R direction on the disc after the middle big wheel.
Muon::MuonStationIndex::LayerIndex LayIdx
Abrivation for the layer index.
bool isBIS78(const MuonGMR4::MuonReadoutElement *element) const
Helper function determining whether a readout element is BIS78.
Gaudi::Property< bool > m_assignActiveMaterial
Flag to assign active material on the chambers.
StatusCode initialize() override
Gaudi::Property< std::size_t > m_nPhiBinsBM
Number of bins in phi direction on the BM cylinder surface.
std::shared_ptr< const Acts::ISurfaceMaterial > getActiveMaterial(const T &element) const
Get the active material for a given element representing the chamber/sector.
Gaudi::Property< std::size_t > m_nZBinsBO
Number of bins in Z direction on the BM cylinder surface.
Gaudi::Property< std::size_t > m_nPhiBinsBO
Number of bins in phi direction on the BM cylinder surface.
std::shared_ptr< Acts::Experimental::MaterialDesignatorBlueprintNode > materialNodePtr
Abrivation of the material node pointer.
Gaudi::Property< std::size_t > m_nRBinsEI2
Number of bins in R direction on the disc after the NSW.
This is a "hash" representation of an Identifier.
Readout element to describe the Monitored Drift Tube (Mdt) chambers Mdt chambers usually comrpise out...
static IdentifierHash measurementHash(unsigned layerNumber, unsigned tubeNumber)
Constructs a Measurement hash from layer && tube number.
MuonReadoutElement is an abstract class representing the geometry of a muon detector.
int stationEta() const
Returns the stationEta (positive A site, negative C site)
Muon::MuonStationIndex::ChIndex chamberIndex() const
Returns the chamber index of the Identifier (MMS & STS) have the same chamber Index (EIS)
The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout ge...
std::string to_string(const DetectorType &type)
@ Mm
Maybe not needed in the migration.
@ Tgc
Resitive Plate Chambers.
@ Rpc
Monitored Drift Tubes.
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
Amg::Transform3D getTranslateZ3D(const double Z)
: Returns a shift transformation along the z-axis
Amg::Transform3D getTranslateY3D(const double Y)
: Returns a shift transformation along the y-axis
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 3, 1 > Vector3D
const std::string & layerName(LayerIndex index)
convert LayerIndex into a string
std::pair< DetectorRegionIndex, ChIndex > decomposeRegionChamberHash(unsigned int hash)
decompose the hash into Region and Chamber
StIndex toStationIndex(ChIndex index)
convert ChIndex into StIndex
const std::string & chName(ChIndex index)
convert ChIndex into a string
const std::string & regionName(DetectorRegionIndex index)
convert DetectorRegionIndex into a string
LayerIndex toLayerIndex(ChIndex index)
convert ChIndex into LayerIndex
DetectorRegionIndex toDetectorRegionIndex(ChIndex index, int8_t etaSign)
convert ChamberIndex + etaSign into DetectorRegionIndex
ChIndex
enum to classify the different chamber layers in the muon spectrometer
Set of parameters to describe a MDT chamber.
#define THROW_EXCEPTION(MESSAGE)