|
ATLAS Offline Software
|
Go to the documentation of this file.
5 #if defined(FLATTEN) && defined(__GNUC__)
7 #pragma GCC optimize "-fno-var-tracking-assignments"
19 #include <GaudiKernel/SystemOfUnits.h>
21 #include "Acts/Geometry/TrapezoidVolumeBounds.hpp"
36 return StatusCode::SUCCESS;
38 template <
class EnvelopeType>
39 #if defined(FLATTEN) && defined(__GNUC__)
48 const Acts::Volume& boundVol,
50 const std::string&
descr,
55 Acts::Vector3 posInVolFrame((boundVol.transform().inverse()) * point);
56 if (boundVol.volumeBounds().inside(posInVolFrame,
tolerance)) {
58 <<
", point "<<
descr <<
" is inside of the chamber "<<std::endl<<chamb<<std::endl
59 <<
"Local position:" <<
Amg::toString(boundVol.itransform() * point));
60 return StatusCode::SUCCESS;
65 planeTrapezoid.
defineTrapezoid(chamb.halfXShort(), chamb.halfXLong(), chamb.halfY());
69 if (std::abs(locPos.z()) - chamb.halfZ() < -
tolerance &&
70 planeTrapezoid.insideTrapezoid(axisSwap*locPos.block<2,1>(0,0))) {
71 return StatusCode::SUCCESS;
73 planeTrapezoid.defineStripLayout(locPos.y() * Amg::Vector2D::UnitX(), 1, 1, 1);
76 <<std::endl<<std::endl<<chamb<<std::endl<<
"Local position "<<
Amg::toString(locPos)
79 return StatusCode::FAILURE;
82 template <
class EnvelopeType>
84 const EnvelopeType& envelope)
const {
85 std::shared_ptr<Acts::Volume> boundVol = envelope.boundingVolume(gctx);
88 if constexpr (std::is_same_v<EnvelopeType, SpectrometerSector>) {
89 if (readOut->msSector() != &envelope) {
91 <<std::endl<<(*readOut->msSector())<<std::endl<<envelope);
92 return StatusCode::FAILURE;
94 }
else if constexpr (std::is_same_v<EnvelopeType, Chamber>) {
95 if (readOut->chamber() != &envelope) {
97 <<std::endl<<(*readOut->chamber())<<std::endl<<envelope);
98 return StatusCode::FAILURE;
101 switch (readOut->detectorType()) {
125 return StatusCode::FAILURE;
129 ATH_MSG_DEBUG(
"All "<<reEles.size()<<
" readout elements are embedded in "<<envelope);
130 return StatusCode::SUCCESS;
135 unsigned int edgeIdx{0};
136 using BoundEnum = Acts::TrapezoidVolumeBounds::BoundValues;
137 const auto& bounds =
static_cast<const Acts::TrapezoidVolumeBounds&
>(volume.volumeBounds());
139 for (
const double signX : {-1., 1.}) {
140 for (
const double signY : { -1., 1.}) {
141 for (
const double signZ: {-1., 1.}) {
142 const Amg::Vector3D edge{signX* (signY>0 ? bounds.get(BoundEnum::eHalfLengthXposY) :
143 bounds.get(BoundEnum::eHalfLengthXnegY)),
144 signY*bounds.get(BoundEnum::eHalfLengthY),
145 signZ*bounds.get(BoundEnum::eHalfLengthZ)};
146 edges[edgeIdx] = volume.transform() * edge;
157 if (!gctx.isValid()) {
159 return StatusCode::FAILURE;
167 const std::shared_ptr<Acts::Volume> secVolume = sector->boundingVolume(*gctx);
170 unsigned int edgeCount{0};
174 chamber->readoutEles().front()->identify()));
183 return StatusCode::SUCCESS;
185 template <
class EnvelopeType>
189 const Acts::Volume& detVol)
const {
207 "bottom of the tube box", measId));
209 "sealing of the tube box", measId));
212 "wall to the previous tube", measId));
214 "wall to the next tube", measId));
217 return StatusCode::SUCCESS;
219 template<
class EnvelopeType>
223 const Acts::Volume& detVol)
const {
230 for (
bool measPhi : {
false,
true}) {
232 for (
int strip = 1; strip <=
nStrips; ++strip) {
242 return StatusCode::SUCCESS;
244 template <
class EnevelopeType>
248 const Acts::Volume& detVol)
const {
260 return StatusCode::SUCCESS;
262 template <
class EnevelopeType>
266 const Acts::Volume& detVol)
const {
272 for(
unsigned int strip =
firstStrip; strip <=
mm.numStrips(gasGapHash); ++strip){
280 return StatusCode::SUCCESS;
282 template <
class EnvelopeType>
286 const Acts::Volume& detVol)
const{
291 for(
unsigned int nch = 1; nch <= stgc.
nChTypes(); ++nch){
295 switch (channelType){
296 case sTgcReadoutElement::ReadoutChannelType::Pad:
299 case sTgcReadoutElement::ReadoutChannelType::Wire:
307 for(
unsigned int strip = 1; strip <=
nStrips; ++strip){
311 if(channelType == sTgcReadoutElement::ReadoutChannelType::Wire || channelType == sTgcReadoutElement::ReadoutChannelType::Strip){
324 return StatusCode::SUCCESS;
def retrieve(aClass, aKey=None)
int doubletPhiMax() const
Returns the maximum phi panel.
unsigned int numWireGangs(unsigned int gasGap) const
Returns the number of wire gangs for a given gasGap [1-3].
int multilayer() const
Returns the multilayer of the sTgcReadoutElement.
The TransientConstSharedPtr allows non-const access if the pointer itself is non-const but in the con...
static IdentifierHash createHash(const int gasGap, const int strip)
A spectrometer sector forms the envelope of all chambers that are placed in the same MS sector & laye...
std::set< const SpectrometerSector *, MSEnvelopeSorter > MuonSectorSet
unsigned int numTubesInLay() const
Returns the number of tubes per layer.
static IdentifierHash measurementHash(unsigned int layerNumber, unsigned int tubeNumber)
Transform the layer and tube number to the measurementHash.
unsigned int nGasGaps() const
Returns the number of gasgaps described by this ReadOutElement (usally 2 or 3)
Amg::Vector3D channelPosition(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the center of the measurement channel eta measurement: wire gang center phi measurement: stri...
@ Tgc
Resitive Plate Chambers.
unsigned int nGasGaps() const
Returns the number of gasgaps described by this ReadOutElement (usally 2 or 3)
The MuonReadoutElement is an abstract class representing the geometry representing the muon detector.
unsigned int nChTypes() const
Number of Channel Types.
Amg::Vector3D readOutPos(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global position of the readout card.
ReadoutChannelType
ReadoutChannelType to distinguish the available readout channels Pad - pad readout channel Strip - et...
Amg::Vector3D rightStripEdge(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global position of the strip edge at negative local Y.
#define ATH_MSG_VERBOSE(x)
IdentifierHash measurementHash(const Identifier &measId) const override final
Constructs the identifier hash from the full measurement Identifier.
const parameterBook & getParameters() const
SpectrometerSector::ChamberSet ChamberSet
const ServiceHandle< StoreGateSvc > & detStore() const
The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
An algorithm that can be simultaneously executed in multiple threads.
unsigned int nEtaStrips() const
Number of strips measuring the eta coordinate.
unsigned int numStrips(unsigned int gasGap) const
Returns the number of strips for a given gasGap [1-3].
Identifier measurementId(const IdentifierHash &measHash) const override final
Converts the measurement hash back to the full Identifier.
static IdentifierHash createHash(const unsigned int gasGap, const unsigned int channelType, const unsigned int channel, const unsigned int wireInGrp=0)
Create a measurement hash from the Identifier fields.
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
The ReadoutGeomCnvAlg converts the Run4 Readout geometry build from the GeoModelXML into the legacy M...
@ Mm
Maybe not needed in the migration.
::StatusCode StatusCode
StatusCode definition for legacy code.
std::set< const Chamber *, MSEnvelopeSorter > MuonChamberSet
int doubletPhi() const
Returns the doublet Phi field of the MuonReadoutElement identifier.
unsigned int numLayers() const
Returns the number of tube layer.
Eigen::Affine3d Transform3D
Amg::Vector3D stripPosition(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the position of the strip center.
Amg::Vector3D leftStripEdge(const ActsGeometryContext &ctx, const IdentifierHash &measHash) const
std::vector< const MuonReadoutElement * > ReadoutSet
Define the list of read out elements of the chamber.
void defineTrapezoid(double HalfShortY, double HalfLongY, double HalfHeight)
Defines the edges of the trapezoid.
int doubletZ() const
Returns the doublet Z field of the MuonReadoutElement identifier.
StatusCode initialize(bool used=true)
If this object is used as a property, then this should be called during the initialize phase.
Identifier measurementId(const IdentifierHash &measHash) const override final
Converts the measurement hash back to the full Identifier.
Include the GeoPrimitives which need to be put first.
double innerTubeRadius() const
Returns the inner tube radius.
int nStrips(const MuonGM::TgcReadoutElement &readoutEle, int layer)
Amg::Vector3D globalChannelPosition(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global pad/strip/wireGroup position.
std::string to_string(const DetectorType &type)
Amg::Vector3D rightStripEdge(const ActsGeometryContext &ctx, const IdentifierHash &measHash) const
Identifier identify() const override final
Return the athena identifier.
unsigned int nPhiStrips() const
Number of strips measuring the phi coordinate.
Eigen::Matrix< double, 3, 1 > Vector3D
unsigned int numWires(unsigned int gasGap) const
Number of wires in the gas gap.
unsigned int numLayers() const
Returns the number of gas gap layers.
MuonSectorSet getAllSectors() const
: Returns all MuonChambers associated with the readout geometry
Amg::Vector3D leftStripEdge(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global posiition of the strip edge at positive local Y.
@ Rpc
Monitored Drift Tubes.
unsigned int numPads(const Identifier &measId) const
Pads Total number of pads in the given layer.
unsigned int numStrips(const Identifier &measId) const
Strips Number of strips in a chamber.
const Amg::Transform3D & localToGlobalTrans(const ActsGeometryContext &ctx) const
Returns the local to global transformation into the ATLAS coordinate system.
Amg::Vector3D globalTubePos(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global position of the tube center.
const parameterBook & getParameters() const
Amg::Vector3D highVoltPos(const ActsGeometryContext &ctx, const Identifier &measId) const
Returns the global position of the High Voltage connectors.
This is a "hash" representation of an Identifier. This encodes a 32 bit index which can be used to lo...
MuonChamberSet getAllChambers() const
bool isValid(const IdentifierHash &measHash) const