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");
86 template<
typename... T>
87 bool isNullVariant(std::variant<T...> variant) {
88 return std::visit([](
auto&& ptr) {
99 return StatusCode::SUCCESS;
106EnvelopeSet_t barrelStations, endcapOuterAStations, endcapOuterCStations,
107 endcapMiddleAStations, endcapMiddleCStations;
110 elements =
m_detMgr->getAllSectors();
112 elements =
m_detMgr->getAllChambers();
115std::visit([&](
auto& elems) {
116 using SetType = std::decay_t<
decltype(elems)>;
119 SetType
barrel, endcapA, endcapC, endcapMiddleA, endcapMiddleC;
121 for (
const auto& element : elems) {
123 {StIdx::BI, StIdx::BM, StIdx::BO, StIdx::BE, StIdx::EE, StIdx::EI},
125 barrel.push_back(element);
127 endcapA.push_back(element);
129 endcapC.push_back(element);
131 endcapMiddleA.push_back(element);
133 endcapMiddleC.push_back(element);
136 <<
" not assigned to any station!");
141 barrelStations = std::move(
barrel);
142 endcapOuterAStations = std::move(endcapA);
143 endcapOuterCStations = std::move(endcapC);
144 endcapMiddleAStations = std::move(endcapMiddleA);
145 endcapMiddleCStations = std::move(endcapMiddleC);
149auto muonNode = std::make_shared<Acts::Experimental::CylinderContainerBlueprintNode>(
"MuonNode", Acts::AxisDirection::AxisZ);
151Acts::VolumeBoundFactory boundsFactory{};
152auto barrelNode =
buildMuonNode(gctx, barrelStations,
"BI_BM_BO_EE_EI", Acts::GeometryIdentifier().withVolume(s_muonBarrelId), boundsFactory, {ChIdx::BIS, ChIdx::BML, ChIdx::BOL,
153 ChIdx::EIS, ChIdx::EIL});
154auto endcapANode =
buildMuonNode(gctx, endcapOuterAStations,
"EO_A", Acts::GeometryIdentifier().withVolume(s_muonEndcapAId), boundsFactory);
155auto endcapCNode =
buildMuonNode(gctx, endcapOuterCStations,
"EO_C", Acts::GeometryIdentifier().withVolume(s_muonEndcapCId), boundsFactory);
156auto endcapMiddleANode =
buildMuonNode(gctx, endcapMiddleAStations,
"EM_A", Acts::GeometryIdentifier().withVolume(s_muonEndcapMiddleAId), boundsFactory, {ChIdx::EML, ChIdx::EMS});
157auto endcapMiddleCNode =
buildMuonNode(gctx, endcapMiddleCStations,
"EM_C", Acts::GeometryIdentifier().withVolume(s_muonEndcapMiddleCId), boundsFactory, {ChIdx::EML, ChIdx::EMS});
161 barrelNode->addChild(std::move(childNode));
163muonNode->addChild(std::move(barrelNode));
164muonNode->addChild(std::move(endcapANode));
165muonNode->addChild(std::move(endcapCNode));
166muonNode->addChild(std::move(endcapMiddleANode));
167muonNode->addChild(std::move(endcapMiddleCNode));
173std::shared_ptr<Acts::Experimental::StaticBlueprintNode>
176 const std::string& name,
177 const Acts::GeometryIdentifier&
id,
178 Acts::VolumeBoundFactory& boundsFactory,
179 const std::vector<ChIdx>& passiveStationIds)
const {
182 std::vector<std::string> stationNames;
185 std::vector<std::variant<staticNodePtr, materialNodePtr>> nodes;
187 double innerRadius{0.0};
188 double outerRadius{std::numeric_limits<double>::lowest()};
189 double maxZ{std::numeric_limits<double>::lowest()};
190 double minZ{std::numeric_limits<double>::max()};
192 std::vector<std::shared_ptr<Acts::Surface>> passiveSurfaces;
194 std::visit([&](
const auto& elems){
196 using SetType = std::decay_t<
decltype(elems)>;
197 std::unordered_map<unsigned int, SetType> elementsPerStation;
199 for(
const auto& element : elems){
200 std::unique_ptr<Acts::TrackingVolume> vol{};
202 vol = std::make_unique<Acts::TrackingVolume>(*element->boundingVolume(*context),
203 element->identString());
205 vol = std::make_unique<Acts::TrackingVolume>(element->localToGlobalTransform(*context),
207 element->identString());
210 Acts::GeometryIdentifier chId =
id.withLayer(chamberId++);
211 vol->assignGeometryId(chId);
214 std::pair<std::vector<blueprintNodePtr>,std::vector<surfacePtr>> innerStructure =
getSensitiveElements(*context, *element, chId, boundsFactory);
215 for(
auto& surface: innerStructure.second){
216 vol->addSurface(surface);
220 for(
const auto& surface: vol->volumeBounds().orientedSurfaces(vol->localToGlobalTransform(gctx))) {
221 const auto& surfaceRepr = (*surface.surface);
222 const Acts::Polyhedron& polyhedron = surfaceRepr.polyhedronRepresentation(gctx);
225 maxZ = std::max(maxZ, center.z());
226 minZ = std::min(minZ, center.z());
230 outerRadius = std::max(outerRadius, vertex.perp());
234 std::variant<staticNodePtr, materialNodePtr> chamberNode;
235 const bool isSingleMdt =
236 (element->readoutEles().
size() == 1 &&
248 innerStructure.first.clear();
250 if (isNullVariant(chamberNode)) {
253 nodes.push_back(std::move(chamberNode));
256 if(!Acts::rangeContainsValue(passiveStationIds, element->chamberIndex())){
261 elementsPerStation[regionChamberHash(detIdx, element->chamberIndex())].push_back(element);
268 double halfLengthZ = 0.5 * std::abs(maxZ - minZ);
269 ATH_MSG_DEBUG(
"Inner radius: " << innerRadius<<
", outer radius: " << outerRadius
270 <<
", max Z: " << maxZ<<
", min Z: " << minZ<<
", half length Z: " << halfLengthZ);
274 auto bounds = boundsFactory.makeBounds<Acts::CylinderVolumeBounds>(innerRadius, outerRadius, halfLengthZ);
275 auto volume = std::make_unique<Acts::TrackingVolume>(trf, bounds, name);
276 volume->assignGeometryId(
id);
279 std::ranges::for_each(passiveSurfaces, [&volume](
auto& surf){
280 volume->addSurface(surf);
283 auto muonNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(volume));
286 std::ranges::for_each(nodes, [&muonNode](
auto& nodeVariant){
287 std::visit([&](
auto&& ptr) {
288 muonNode->addChild(ptr);
295std::variant<MuonBlueprintNodeBuilder::staticNodePtr, MuonBlueprintNodeBuilder::materialNodePtr>
298 auto materialNode = std::dynamic_pointer_cast<Acts::Experimental::MaterialDesignatorBlueprintNode>(chamberVolumeNode);
301 auto staticNode = std::dynamic_pointer_cast<Acts::Experimental::StaticBlueprintNode>(chamberVolumeNode);
306std::variant<MuonBlueprintNodeBuilder::staticNodePtr, MuonBlueprintNodeBuilder::materialNodePtr>
308 std::unique_ptr<Acts::TrackingVolume>& vol,
309 const std::vector<blueprintNodePtr>& innerStructure)
const{
311 const Acts::VolumeBounds& bounds = vol->volumeBounds();
312 staticNodePtr staticNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(vol));
313 for (
auto& childNode : innerStructure) {
314 auto node = std::dynamic_pointer_cast<Acts::Experimental::StaticBlueprintNode>(childNode);
316 staticNode->addChild(std::move(
node));
322 auto materialNode = std::make_shared<Acts::Experimental::MaterialDesignatorBlueprintNode>(element->identString() +
"_MaterialNode");
324 materialNode->addChild(staticNode);
333 const Acts::GeometryIdentifier& chId,
334 Acts::VolumeBoundFactory& boundsFactory)
const
335 requires(std::is_same_v<T, MuonGMR4::Chamber> || std::is_same_v<T, MuonGMR4::SpectrometerSector>){
337 std::vector<blueprintNodePtr> readoutVolumes;
338 std::vector<surfacePtr> readoutSurfaces;
339 Acts::GeometryIdentifier::Value mdtId{1};
343 std::vector<surfacePtr> detSurfaces = readoutEle->getSurfaces();
344 switch(readoutEle->detectorType()){
349 std::unique_ptr<ActsTrk::VolumePlacement> placement{};
352 Acts::Experimental::MultiWireVolumeBuilder::Config mwCfg;
353 mwCfg.name =
m_detMgr->idHelperSvc()->toStringDetEl(mdtReadoutEle->identify());
354 mwCfg.mlSurfaces = detSurfaces;
355 mwCfg.transform = readoutEle->localToGlobalTransform(gctx);
359 std::shared_ptr<Acts::Experimental::MaterialDesignatorBlueprintNode> mdtMaterialNode;
363 if(
isBIS78(readoutEle) && mdtReadoutEle->multilayer() == 2){
367 std::vector<double> tubeLengths;
368 tubeLengths.reserve(mdtReadoutEle->numTubesInLay());
369 for(std::size_t tube = 1; tube < mdtReadoutEle->numTubesInLay(); ++tube){
371 const auto& surface = mdtReadoutEle->surface(tubeHash);
372 const auto& lBounds =
static_cast<const Acts::LineBounds&
>(surface.bounds());
373 using BoundEnum = Acts::LineBounds::BoundValues;
374 const double tubeLength = 2.*lBounds.get(BoundEnum::eHalfLengthZ);
377 auto [minX,maxX] = std::ranges::minmax_element(tubeLengths);
378 int nSmallTubes = std::count_if(tubeLengths.begin(), tubeLengths.end(), [minX](
double length){
379 return std::abs(*minX-length) < Acts::s_epsilon;
383 constexpr double extraMargin = 1._cm;
384 double y2 = (nSmallTubes+1.)*parameters.tubePitch;
385 double y1 = 2.*parameters.halfY + extraMargin - y2;
387 placement = std::make_unique<ActsTrk::VolumePlacement>(*readoutEle,
391 mwCfg.bounds = boundsFactory.makeBounds<Acts::DiamondVolumeBounds>(0.5*(*maxX), 0.5*(*maxX), 0.5*(*minX),
392 y1, y2, parameters.halfHeight);
396 placement = std::make_unique<ActsTrk::VolumePlacement>(*readoutEle);
399 if(std::abs(parameters.shortHalfX - parameters.longHalfX) < Acts::s_epsilon){
400 mwCfg.bounds = boundsFactory.makeBounds<Acts::CuboidVolumeBounds>(parameters.shortHalfX,
402 parameters.halfHeight);
404 mwCfg.bounds = boundsFactory.makeBounds<Acts::TrapezoidVolumeBounds>(parameters.shortHalfX,
405 parameters.longHalfX,
407 parameters.halfHeight);
410 mwCfg.alignablePlacement = placement.get();
412 element.addPlacement(std::move(placement));
414 mwCfg.binning = {{{Acts::AxisDirection::AxisY, Acts::AxisBoundaryType::Bound,
417 static_cast<std::size_t
>(std::lround(2 * parameters.halfY / parameters.tubePitch))}, 2u},
418 {{Acts::AxisDirection::AxisZ, Acts::AxisBoundaryType::Bound,
419 -parameters.halfHeight,
420 parameters.halfHeight,
421 static_cast<std::size_t
>(std::lround(2 * parameters.halfHeight / parameters.tubePitch))}, 1u}};
422 Acts::Experimental::MultiWireVolumeBuilder mdtBuilder{mwCfg};
423 std::unique_ptr<Acts::TrackingVolume> mdtVolume = mdtBuilder.buildVolume();
425 mdtVolume->assignGeometryId(chId.withExtra(mdtId++));
430 mdtMaterialNode = std::make_shared<Acts::Experimental::MaterialDesignatorBlueprintNode>(element.identString() +
"_MaterialNode");
431 configureMaterialFaces(*mdtMaterialNode, mdtVolume->volumeBounds(),
getActiveMaterial(element));
432 auto staticNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(mdtVolume));
433 mdtMaterialNode->addChild(std::move(staticNode));
434 readoutVolumes.push_back(std::move(mdtMaterialNode));
437 auto mdtNode = std::make_shared<Acts::Experimental::StaticBlueprintNode>(std::move(mdtVolume));
438 mdtNode->setNavigationPolicyFactory(mdtBuilder.createNavigationPolicyFactory());
439 readoutVolumes.push_back(std::move(mdtNode));
448 readoutSurfaces.insert(readoutSurfaces.end(), std::make_move_iterator(detSurfaces.begin()),
449 std::make_move_iterator(detSurfaces.end()));
460 return std::make_pair(std::move(readoutVolumes), std::move(readoutSurfaces));
470template<
typename ElementSet_t>
471std::vector<std::shared_ptr<Acts::Surface>>
473 const Acts::GeometryContext& gctx,
474 const std::unordered_map<unsigned int, ElementSet_t>& elementsPerStation)
const {
481 constexpr double margin{4._mm};
483 std::vector<std::shared_ptr<Acts::Surface>> surfaces;
484 surfaces.reserve(elementsPerStation.size());
485 LayIdx layIdx = LayIdx::LayerIndexMax;
486 DetIdx detIdx = DetIdx::DetectorRegionIndexMax;
494 switch (readoutEle->detectorType()) {
496 const auto* techEle =
498 if (techEle->multilayer() == 2) {
504 const auto* techEle =
506 if (techEle->doubletZ() == 2) {
514 return isBIS78(readoutEle) && reject;
517 for(
const auto& [hash, elements] : elementsPerStation){
524 double maxZ{std::numeric_limits<double>::lowest()};
525 double minZ{std::numeric_limits<double>::max()};
526 double rMin{std::numeric_limits<double>::max()};
527 double rMax{std::numeric_limits<double>::lowest()};
529 for(
const auto& el : elements){
531 if(rejectBIS78(el->readoutEles().front())){
535 const auto& bounds = el->bounds();
536 for(
const auto& surface : bounds->orientedSurfaces(locToGlobal)){
537 const auto& surfaceRepr = (*surface.surface);
539 rMin = std::min(rMin, center.perp());
540 minZ = std::min(minZ, center.z());
541 maxZ = std::max(maxZ, center.z());
542 rMax = std::max(rMax, center.perp());
546 double halfZ = 0.5*std::abs(maxZ-minZ);
551 const auto& testCh = elements.front();
552 int8_t side = testCh->side();
553 switch (testCh->chamberIndex()) {
557 side > 0 ? zShift = minZ - margin : zShift = maxZ + margin;
559 auto surface = Acts::Surface::makeShared<Acts::DiscSurface>(trf, std::make_shared<Acts::RadialBounds>(rMin, rMax));
562 surfaces.push_back(surface);
570 if(testCh->chamberIndex() == ChIdx::EIL){
573 side > 0 ? zShift = maxZ + margin : zShift = minZ - margin;
575 auto surface = Acts::Surface::makeShared<Acts::DiscSurface>(trf,
576 std::make_shared<Acts::RadialBounds>(rMin, rMax));
579 surfaces.push_back(surface);
585 auto surface = Acts::Surface::makeShared<Acts::CylinderSurface>(trf,
586 std::make_shared<Acts::CylinderBounds>(rMin - margin, halfZ));
589 surfaces.push_back(surface);
592 THROW_EXCEPTION(
"No implementation of passive material surface for this station!!!! - sorry :) ");
594 ATH_MSG_VERBOSE(
"Putting passive material surface for station " <<
layerName(layIdx) <<
"/ "<<
regionName(detIdx) <<
": minZ = " << minZ <<
", maxZ = " << maxZ<<
"and radius "<< rMax);
597 if(msgLvl(MSG::VERBOSE)){
598 std::stringstream stream{};
599 for(
const auto& surf : surfaces){
600 stream<<
" at position : "<<
Amg::toString(surf->center(gctx))
601 <<
"with bounds "<< surf->bounds()<<std::endl;
604 <<
" surfaces for passive material description : "<<std::endl<<stream.str());
611std::shared_ptr<const Acts::ISurfaceMaterial>
613 requires(std::is_same_v<T, MuonGMR4::Chamber> ||
614 std::is_same_v<T, MuonGMR4::SpectrometerSector>) {
616 const float thickness = element.halfZ();
617 PVConstLink parentVolume = element.readoutEles().front()->getMaterialGeom()->getParent();
618 GeoModelTools::GeoMaterialHelper geoMaterialHelper;
619 std::pair<GeoModelTools::GeoMaterialPtr, double> geoMaterials = geoMaterialHelper.collectMaterial(parentVolume);
621 const Acts::Material aMat = ActsPlugins::GeoModel::geoMaterialConverter(*geoMaterials.first);
622 Acts::MaterialSlab slab{aMat, thickness};
623 std::shared_ptr<Acts::HomogeneousSurfaceMaterial> material = std::make_shared<Acts::HomogeneousSurfaceMaterial>(slab);
624 material->scale(0.5);
632 const std::vector<StIdx>& stationIndex,
634 requires(std::is_same_v<T, MuonGMR4::Chamber> ||
635 std::is_same_v<T, MuonGMR4::SpectrometerSector>) {
639 return etaSignCorrect &&
640 Acts::rangeContainsValue(stationIndex,
toStationIndex(element.chamberIndex()));
644std::shared_ptr<Acts::ISurfaceMaterial>
646 const std::size_t nBins1,
647 const std::size_t nBins2)
const {
648 if (nBins1 == 0 || nBins2 == 0) {
650 <<
" as one of the bin dimensions is zero. nBins1: "<<nBins1<<
", nBins2: "<<nBins2);
653 if (nBins1 == 1 && nBins1 == nBins2) {
654 return std::make_shared<Acts::HomogeneousSurfaceMaterial>();
657 std::vector<Acts::DirectedProtoAxis> pmBinning = {};
659 switch (bounds.type()) {
660 using enum Acts::SurfaceBounds::BoundsType;
662 pmBinning = {{Acts::AxisDirection::AxisZ, Acts::AxisBoundaryType::Bound, nBins1},
663 {Acts::AxisDirection::AxisPhi, Acts::AxisBoundaryType::Bound, nBins2}};
666 pmBinning = {{Acts::AxisDirection::AxisR, Acts::AxisBoundaryType::Bound, nBins1},
667 {Acts::AxisDirection::AxisPhi, Acts::AxisBoundaryType::Bound, nBins2}};
674 return std::make_shared<Acts::ProtoGridSurfaceMaterial>(pmBinning);
676std::pair<std::size_t, std::size_t>
700 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)
size_t size() const
Number of registered mappings.
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.
std::shared_ptr< Acts::Experimental::BlueprintNode > blueprintNodePtr
Abrivation of the blueprint node ptr base class.
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.
std::variant< staticNodePtr, materialNodePtr > buildChamberNode(const blueprintNodePtr &chamberNode) const
Build a static or a material node for a chamber that corresponds to a single blueprint node (e....
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.
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...
@ Mm
Maybe not needed in the migration.
@ Tgc
Resitive Plate Chambers.
@ Rpc
Monitored Drift Tubes.
std::string to_string(const DetectorType &type)
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)