ATLAS Offline Software
Loading...
Searching...
No Matches
MmReadoutElement.cxx
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2025 CERN for the benefit of the ATLAS collaboration
3*/
5
6
8
10#include <GaudiKernel/SystemOfUnits.h>
11#include <optional>
12
13#ifndef SIMULATIONBASE
14# include "Acts/Surfaces/Surface.hpp"
15# include "Acts/Surfaces/TrapezoidBounds.hpp"
16#endif
17
18using namespace ActsTrk;
19
20namespace MuonGMR4 {
22std::ostream& operator<<(std::ostream& ostr, const parameterBook& pars) {
23 ostr<<"chamber shortWidth/longWidth/length [mm]: "<<(2.*pars.halfShortWidth)<<"/";
24 ostr<<(2.*pars.halfLongWidth)<<"/"<<(2.*pars.halfHeight)<<std::endl;
25 return ostr;
26}
27
32
34
36 ATH_MSG_DEBUG("Parameter book "<<parameterBook());
38
39 if (m_pars.layers.empty()) {
40 ATH_MSG_FATAL("The readout element "<<idHelperSvc()->toStringDetEl(identify())<<" doesn't have any layers defined");
41 return StatusCode::FAILURE;
42 }
43#ifndef SIMULATIONBASE
45 m_pars.layerBounds->makeBounds<Acts::TrapezoidBounds>(m_pars.halfShortWidth,
46 m_pars.halfLongWidth,
47 m_pars.halfHeight,
48 90.*Gaudi::Units::deg)));
49#endif
50 for (unsigned int layer = 0; layer < m_pars.layers.size(); ++layer) {
51 IdentifierHash layHash{layer};
52 if (m_pars.layers[layer]->hash() != layHash) {
53 ATH_MSG_FATAL("Layer "<<m_pars.layers[layer]<<" has a very strange hash. Expect "<<layer);
54 return StatusCode::FAILURE;
55 }
57#ifndef SIMULATIONBASE
58 const StripDesign& design{m_pars.layers[layer]->design()};
59
61 m_pars.layerBounds->makeBounds<Acts::TrapezoidBounds>(design.shortHalfHeight(),
62 design.longHalfHeight(),
63 design.halfWidth(),
64 90.*Gaudi::Units::deg + design.stereoAngle())));
65#endif
66 }
67#ifndef SIMULATIONBASE
68 m_pars.layerBounds.reset();
69#endif
70 return StatusCode::SUCCESS;
71}
72
76
77
78#if defined(FLATTEN) && defined(__GNUC__)
79// We compile this function with optimization, even in debug builds; otherwise,
80// the heavy use of Eigen makes it too slow. However, from here we may call
81// to out-of-line Eigen code that is linked from other DSOs; in that case,
82// it would not be optimized. Avoid this by forcing all Eigen code
83// to be inlined here if possible.
84[[gnu::flatten]]
85#endif
87 const IdentifierHash lHash = layerHash(measHash);
88 if (static_cast<unsigned int>(lHash) < m_pars.layers.size()) {
89 return localToGlobalTrans(ctx, lHash) * stripLayer(lHash).localStripPosition(stripNumber(measHash));
90 }
91 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" The layer hash "<<static_cast<unsigned int>(lHash)
92 <<" is out of range. Maximum range "<<m_pars.layers.size());
93 return Amg::Vector3D::Zero();
94}
95
96
97#if defined(FLATTEN) && defined(__GNUC__)
98// We compile this function with optimization, even in debug builds; otherwise,
99// the heavy use of Eigen makes it too slow. However, from here we may call
100// to out-of-line Eigen code that is linked from other DSOs; in that case,
101// it would not be optimized. Avoid this by forcing all Eigen code
102// to be inlined here if possible.
103[[gnu::flatten]]
104#endif
106 const IdentifierHash lHash = layerHash(measHash);
107 if (static_cast<unsigned int>(lHash) < m_pars.layers.size()) {
108 return localToGlobalTrans(ctx, lHash) * stripLayer(lHash).localStripLeftEdge(stripNumber(measHash));
109 }
110 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" The layer hash "<<static_cast<unsigned int>(lHash)
111 <<" is out of range. Maximum range "<<m_pars.layers.size());
112 return Amg::Vector3D::Zero();
113}
114
115#if defined(FLATTEN) && defined(__GNUC__)
116// We compile this function with optimization, even in debug builds; otherwise,
117// the heavy use of Eigen makes it too slow. However, from here we may call
118// to out-of-line Eigen code that is linked from other DSOs; in that case,
119// it would not be optimized. Avoid this by forcing all Eigen code
120// to be inlined here if possible.
121[[gnu::flatten]]
122#endif
124 const IdentifierHash lHash = layerHash(measHash);
125 if (static_cast<unsigned int>(lHash) < m_pars.layers.size()) {
126 return localToGlobalTrans(ctx, lHash) * stripLayer(lHash).localStripRightEdge(stripNumber(measHash));
127 }
128 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" The layer hash "<<static_cast<unsigned int>(lHash)
129 <<" is out of range. Maximum range "<<m_pars.layers.size());
130 return Amg::Vector3D::Zero();
131}
132
133
134}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_FATAL(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
This is a "hash" representation of an Identifier.
const StripLayer & stripLayer(const Identifier &measId) const
StatusCode initElement() override final
Element initialization.
MmReadoutElement(defineArgs &&args)
const parameterBook & getParameters() const
static unsigned int stripNumber(const IdentifierHash &measHash)
Amg::Transform3D fromGapToChamOrigin(const IdentifierHash &layerHash) const
IdentifierHash layerHash(const Identifier &measId) const override final
Amg::Vector3D leftStripEdge(const ActsTrk::GeometryContext &ctx, const Identifier &measId) const
Returns the global position of the strip edge.
Amg::Vector3D stripPosition(const ActsTrk::GeometryContext &ctx, const Identifier &measId) const
Returns the position of the strip center.
Amg::Vector3D rightStripEdge(const ActsTrk::GeometryContext &ctx, const Identifier &measId) const
Returns the global position of the strip edge.
const Amg::Transform3D & localToGlobalTrans(const ActsTrk::GeometryContext &ctx) const
Returns the local to global transformation into the ATLAS coordinate system.
StatusCode planeSurfaceFactory(const IdentifierHash &hash, std::shared_ptr< const Acts::PlanarBounds > pBounds)
Identifier identify() const override final
Return the athena identifier.
const Muon::IMuonIdHelperSvc * idHelperSvc() const
Returns the pointer to the muonIdHelperSvc.
StatusCode insertTransform(const IdentifierHash &hash)
Inserts a transfomration for caching.
static IdentifierHash geoTransformHash()
Returns the hash that is associated with the surface cache holding the transformation that is placing...
double halfWidth() const
Returns the half height of the strip panel.
double stereoAngle() const
Returns the value of the stereo angle.
double shortHalfHeight() const
Returns the shorter half height of the panel.
double longHalfHeight() const
Returns the longer half height of the panel.
Amg::Vector3D localStripRightEdge(unsigned int stripNum, bool phiView=false) const
Returns the position of the right strip edge at (negative y in the strip design description) in the l...
Amg::Vector3D localStripPosition(unsigned int stripum, bool phiView=false) const
Returns the position of the strip centre expressed in the frame of the local readout plane.
const Amg::Transform3D & toOrigin() const
Returns the transformation to go from the strip layer center to the origin of the Strip chamber.
Amg::Vector3D localStripLeftEdge(unsigned int stripNum, bool phiView=false) const
Returns the position of the strip edge at (positive y in the strip design description) in the local c...
The AlignStoreProviderAlg loads the rigid alignment corrections and pipes them through the readout ge...
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 3, 1 > Vector3D
The ReadoutGeomCnvAlg converts the Run4 Readout geometry build from the GeoModelXML into the legacy M...
std::ostream & operator<<(std::ostream &ostr, const Chamber::defineArgs &args)
Definition Chamber.cxx:14
MmReadoutElement::parameterBook parameterBook
STL namespace.
Set of parameters to describe a RPC chamber.