ATLAS Offline Software
Classes | Public Types | Public Member Functions | Private Attributes | List of all members
MuonGMR4::Chamber Class Reference

#include <Chamber.h>

Collaboration diagram for MuonGMR4::Chamber:

Classes

struct  defineArgs
 

Public Types

using ReadoutSet = std::vector< const MuonReadoutElement * >
 Define the list of read out elements of the chamber. More...
 

Public Member Functions

 Chamber (defineArgs &&args)
 Standard constructor taking the defineArgs. More...
 
 Chamber (const Chamber &other)=delete
 delete the copy constructors More...
 
const Chamberoperator= (const Chamber &other)=delete
 
bool operator< (const Chamber &other) const
 Comparison operator for set ordering. More...
 
std::string identString () const
 Define a string of the chamber used for debugging. More...
 
const Muon::IMuonIdHelperSvcidHelperSvc () const
 Returns a pointer to the idHelperSvc. More...
 
Muon::MuonStationIndex::ChIndex chamberIndex () const
 Returns the chamber index. More...
 
ActsTrk::DetectorType detectorType () const
 Returns the first readout elements detectorType (sorted by techIdx) More...
 
int stationPhi () const
 Returns the station phi of the chamber. More...
 
int stationEta () const
 Returns the station eta of the chamber. More...
 
int8_t side () const
 Returns the side of the chamber. More...
 
int stationName () const
 Returns an integer representing the stationName. More...
 
int sector () const
 Returns the MS sector of the chamber. More...
 
bool barrel () const
 Returns whether the chamber is placed in the barrel. More...
 
const ReadoutSetreadoutEles () const
 Returns the list of contained readout elements. More...
 
const Amg::Transform3DlocalToGlobalTrans (const ActsTrk::GeometryContext &gctx) const
 Returns the transformation chamber frame -> global transformation. More...
 
Amg::Transform3D globalToLocalTrans (const ActsTrk::GeometryContext &gctx) const
 Returns the global -> local transformation. More...
 
const Acts::PlaneSurface & surface () const
 Returns the surface associated with the chamber. More...
 
double halfXLong () const
 Long-extend of the chamber in the x-direction at positive Y. More...
 
double halfXShort () const
 Short extend of the chamber in the x-direction at negative Y. More...
 
double halfY () const
 Extend of the chamber in the y-direction. More...
 
double halfZ () const
 Thickness of the chamber in the z-direction. More...
 
const defineArgsparameters () const
 Returns the reference to the defining parameters of the chamber. More...
 
std::shared_ptr< Acts::Volume > boundingVolume (const ActsTrk::GeometryContext &gctx) const
 Returns the Acts::Volume representation of the chamber. More...
 
std::shared_ptr< Acts::TrapezoidVolumeBounds > bounds () const
 Returns the volume bounds. More...
 
const SpectrometerSectorparent () const
 Returns the pointer to the MS sector enclosing the chamber. More...
 
void setParent (const SpectrometerSector *parent)
 Sets the connection to the MS sector enclosing the chamber. More...
 

Private Attributes

defineArgs m_args {}
 
const SpectrometerSectorm_parent {nullptr}
 

Detailed Description

Definition at line 23 of file Chamber.h.

Member Typedef Documentation

◆ ReadoutSet

Define the list of read out elements of the chamber.

Definition at line 26 of file Chamber.h.

Constructor & Destructor Documentation

◆ Chamber() [1/2]

MuonGMR4::Chamber::Chamber ( defineArgs &&  args)

Standard constructor taking the defineArgs.

Definition at line 29 of file Chamber.cxx.

29  :
30  m_args{std::move(args)} {}

◆ Chamber() [2/2]

MuonGMR4::Chamber::Chamber ( const Chamber other)
delete

delete the copy constructors

Member Function Documentation

◆ barrel()

bool MuonGMR4::Chamber::barrel ( ) const

Returns whether the chamber is placed in the barrel.

Definition at line 96 of file Chamber.cxx.

96  {
97  return !idHelperSvc()->isEndcap(readoutEles().front()->identify());
98  }

◆ boundingVolume()

std::shared_ptr< Acts::Volume > MuonGMR4::Chamber::boundingVolume ( const ActsTrk::GeometryContext gctx) const

Returns the Acts::Volume representation of the chamber.

Parameters
gctxGeometry context carrrying the alignment transformations

Definition at line 114 of file Chamber.cxx.

114  {
115  return std::make_shared<Acts::Volume>(localToGlobalTrans(gctx), bounds());
116  }

◆ bounds()

std::shared_ptr< Acts::TrapezoidVolumeBounds > MuonGMR4::Chamber::bounds ( ) const

Returns the volume bounds.

Definition at line 117 of file Chamber.cxx.

117  {
118  return m_args.bounds;
119  }

◆ chamberIndex()

Muon::MuonStationIndex::ChIndex MuonGMR4::Chamber::chamberIndex ( ) const

Returns the chamber index.

Definition at line 102 of file Chamber.cxx.

102  {
103  return readoutEles().front()->chamberIndex();
104  }

◆ detectorType()

ActsTrk::DetectorType MuonGMR4::Chamber::detectorType ( ) const

Returns the first readout elements detectorType (sorted by techIdx)

Definition at line 106 of file Chamber.cxx.

106  {
107  return readoutEles().front()->detectorType();
108  }

◆ globalToLocalTrans()

Amg::Transform3D MuonGMR4::Chamber::globalToLocalTrans ( const ActsTrk::GeometryContext gctx) const

Returns the global -> local transformation.

Parameters
gctxGeometry context carrrying the alignment transformations

Definition at line 135 of file Chamber.cxx.

135  {
136  return localToGlobalTrans(gctx).inverse();
137  }

◆ halfXLong()

double MuonGMR4::Chamber::halfXLong ( ) const

Long-extend of the chamber in the x-direction at positive Y.

Definition at line 109 of file Chamber.cxx.

109 { return m_args.bounds->get(BoundEnums::eHalfLengthXposY); }

◆ halfXShort()

double MuonGMR4::Chamber::halfXShort ( ) const

Short extend of the chamber in the x-direction at negative Y.

Definition at line 110 of file Chamber.cxx.

110 { return m_args.bounds->get(BoundEnums::eHalfLengthXnegY); }

◆ halfY()

double MuonGMR4::Chamber::halfY ( ) const

Extend of the chamber in the y-direction.

Definition at line 111 of file Chamber.cxx.

111 { return m_args.bounds->get(BoundEnums::eHalfLengthY); }

◆ halfZ()

double MuonGMR4::Chamber::halfZ ( ) const

Thickness of the chamber in the z-direction.

Definition at line 112 of file Chamber.cxx.

112 { return m_args.bounds->get(BoundEnums::eHalfLengthZ); }

◆ identString()

std::string MuonGMR4::Chamber::identString ( ) const

Define a string of the chamber used for debugging.

Definition at line 80 of file Chamber.cxx.

80  {
81  if(idHelperSvc()->isMM(readoutEles().front()->identify()) ||
82  idHelperSvc()->issTgc(readoutEles().front()->identify()) ) {
83  return std::format("MS chamber {:} station {:} eta {:02} phi {:02} ml {:02}",
85  idHelperSvc()->stationNameString(readoutEles().front()->identify()),
87  idHelperSvc()->isMM(readoutEles().front()->identify()) ?
88  idHelperSvc()->mmIdHelper().multilayer(readoutEles().front()->identify()) :
89  idHelperSvc()->stgcIdHelper().multilayer(readoutEles().front()->identify()));
90  }
91  return std::format("MS chamber {:} station {:} eta {:02} phi {:02}",
93  idHelperSvc()->stationNameString(readoutEles().front()->identify()),
94  stationEta(), stationPhi());
95  }

◆ idHelperSvc()

const Muon::IMuonIdHelperSvc * MuonGMR4::Chamber::idHelperSvc ( ) const

Returns a pointer to the idHelperSvc.

Definition at line 99 of file Chamber.cxx.

99  {
100  return readoutEles().front()->idHelperSvc();
101  }

◆ localToGlobalTrans()

const Amg::Transform3D & MuonGMR4::Chamber::localToGlobalTrans ( const ActsTrk::GeometryContext gctx) const

Returns the transformation chamber frame -> global transformation.

Parameters
gctxGeometry context carrrying the alignment transformations

Definition at line 132 of file Chamber.cxx.

132  {
133  return surface().transform(gctx.context());
134  }

◆ operator<()

bool MuonGMR4::Chamber::operator< ( const Chamber other) const

Comparison operator for set ordering.

Definition at line 37 of file Chamber.cxx.

37  {
38 
39 
40  if (stationName() != other.stationName()) {
41  return stationName() < other.stationName();
42  }
43 
44  if(stationPhi() != other.stationPhi()) {
45  return stationPhi() < other.stationPhi();
46  }
47 
48  if(stationEta() != other.stationEta()){
49  return stationEta() < other.stationEta();
50  }
51 
52  if(detectorType() != other.detectorType()){
53 
54  return detectorType() < other.detectorType();
55  }
56 
57  //for NSW order by multilayer for MMLS and STGCs for the large sectors
58  //MMLs and STLs will fall in this case
59  const Identifier& id = readoutEles().front()->identify();
60 
61  bool isNSW = (idHelperSvc()->isMM(id) || idHelperSvc()->issTgc(id));
62 
63  if(isNSW) {
64 
65  const Identifier& otherId = other.readoutEles().front()->identify();
66 
67  if (idHelperSvc()->isMM(id)) {
68  return idHelperSvc()->mmIdHelper().multilayer(id) < idHelperSvc()->mmIdHelper().multilayer(otherId);
69  } else {
70  //stgc case
71  return idHelperSvc()->stgcIdHelper().multilayer(id) < idHelperSvc()->stgcIdHelper().multilayer(otherId);
72  }
73 
74  }
75 
76  return false;
77 
78  }

◆ operator=()

const Chamber& MuonGMR4::Chamber::operator= ( const Chamber other)
delete

◆ parameters()

const Chamber::defineArgs & MuonGMR4::Chamber::parameters ( ) const

Returns the reference to the defining parameters of the chamber.

Definition at line 125 of file Chamber.cxx.

125 { return m_args; }

◆ parent()

const SpectrometerSector * MuonGMR4::Chamber::parent ( ) const

Returns the pointer to the MS sector enclosing the chamber.

Definition at line 138 of file Chamber.cxx.

138 { return m_parent; }

◆ readoutEles()

const Chamber::ReadoutSet & MuonGMR4::Chamber::readoutEles ( ) const

Returns the list of contained readout elements.

Definition at line 126 of file Chamber.cxx.

126  {
127  return m_args.detEles;
128  }

◆ sector()

int MuonGMR4::Chamber::sector ( ) const

Returns the MS sector of the chamber.

Definition at line 124 of file Chamber.cxx.

124 { return idHelperSvc()->sector(readoutEles().front()->identify()); }

◆ setParent()

void MuonGMR4::Chamber::setParent ( const SpectrometerSector parent)

Sets the connection to the MS sector enclosing the chamber.

Definition at line 139 of file Chamber.cxx.

139 { m_parent = parent; }

◆ side()

int8_t MuonGMR4::Chamber::side ( ) const

Returns the side of the chamber.

Definition at line 123 of file Chamber.cxx.

123 { return readoutEles().front()->stationEta() > 0 ? 1 : -1; }

◆ stationEta()

int MuonGMR4::Chamber::stationEta ( ) const

Returns the station eta of the chamber.

Definition at line 121 of file Chamber.cxx.

121 { return readoutEles().front()->stationEta(); }

◆ stationName()

int MuonGMR4::Chamber::stationName ( ) const

Returns an integer representing the stationName.

Definition at line 122 of file Chamber.cxx.

122 { return readoutEles().front()->stationName(); }

◆ stationPhi()

int MuonGMR4::Chamber::stationPhi ( ) const

Returns the station phi of the chamber.

Definition at line 120 of file Chamber.cxx.

120 { return readoutEles().front()->stationPhi(); }

◆ surface()

const Acts::PlaneSurface & MuonGMR4::Chamber::surface ( ) const

Returns the surface associated with the chamber.

Definition at line 129 of file Chamber.cxx.

129  {
130  return *m_args.surface;
131  }

Member Data Documentation

◆ m_args

defineArgs MuonGMR4::Chamber::m_args {}
private

Definition at line 93 of file Chamber.h.

◆ m_parent

const SpectrometerSector* MuonGMR4::Chamber::m_parent {nullptr}
private

Definition at line 94 of file Chamber.h.


The documentation for this class was generated from the following files:
sTgcIdHelper::multilayer
int multilayer(const Identifier &id) const
Definition: sTgcIdHelper.cxx:1022
MuonGMR4::Chamber::defineArgs::surface
std::shared_ptr< const Acts::PlaneSurface > surface
Associated chamber surface.
Definition: Chamber.h:29
xAOD::identify
const Identifier & identify(const UncalibratedMeasurement *meas)
Returns the associated identifier from the muon measurement.
Definition: MuonSpectrometer/MuonPhaseII/Event/xAOD/xAODMuonPrepData/Root/UtilFunctions.cxx:95
MuonGMR4::Chamber::parent
const SpectrometerSector * parent() const
Returns the pointer to the MS sector enclosing the chamber.
Definition: Chamber.cxx:138
Muon::IMuonIdHelperSvc::stgcIdHelper
virtual const sTgcIdHelper & stgcIdHelper() const =0
access to TgcIdHelper
MuonGMR4::Chamber::defineArgs::detEles
ReadoutSet detEles
List of associated readout elements.
Definition: Chamber.h:31
vtune_athena.format
format
Definition: vtune_athena.py:14
python.CaloAddPedShiftConfig.args
args
Definition: CaloAddPedShiftConfig.py:47
MuonGMR4::Chamber::m_parent
const SpectrometerSector * m_parent
Definition: Chamber.h:94
Muon::IMuonIdHelperSvc::mmIdHelper
virtual const MmIdHelper & mmIdHelper() const =0
access to CscIdHelper
MuonGMR4::Chamber::localToGlobalTrans
const Amg::Transform3D & localToGlobalTrans(const ActsTrk::GeometryContext &gctx) const
Returns the transformation chamber frame -> global transformation.
Definition: Chamber.cxx:132
MmIdHelper::multilayer
int multilayer(const Identifier &id) const
Definition: MmIdHelper.cxx:828
MuonGMR4::Chamber::stationEta
int stationEta() const
Returns the station eta of the chamber.
Definition: Chamber.cxx:121
MuonGMR4::Chamber::stationPhi
int stationPhi() const
Returns the station phi of the chamber.
Definition: Chamber.cxx:120
MuonGMR4::Chamber::idHelperSvc
const Muon::IMuonIdHelperSvc * idHelperSvc() const
Returns a pointer to the idHelperSvc.
Definition: Chamber.cxx:99
MuonGMR4::Chamber::readoutEles
const ReadoutSet & readoutEles() const
Returns the list of contained readout elements.
Definition: Chamber.cxx:126
Muon::IMuonIdHelperSvc::isMM
virtual bool isMM(const Identifier &id) const =0
returns whether this is a MM Identifier or not
ActsTrk::to_string
std::string to_string(const DetectorType &type)
Definition: GeometryDefs.h:34
Muon::IMuonIdHelperSvc::isEndcap
virtual bool isEndcap(const Identifier &id) const =0
returns whether this is an endcap Identifier or not
MuonGMR4::Chamber::m_args
defineArgs m_args
Definition: Chamber.h:93
MuonGMR4::Chamber::surface
const Acts::PlaneSurface & surface() const
Returns the surface associated with the chamber.
Definition: Chamber.cxx:129
InDetDD::other
@ other
Definition: InDetDD_Defs.h:16
MuonGMR4::Chamber::bounds
std::shared_ptr< Acts::TrapezoidVolumeBounds > bounds() const
Returns the volume bounds.
Definition: Chamber.cxx:117
MuonGMR4::Chamber::detectorType
ActsTrk::DetectorType detectorType() const
Returns the first readout elements detectorType (sorted by techIdx)
Definition: Chamber.cxx:106
MuonGMR4::Chamber::defineArgs::bounds
std::shared_ptr< Acts::TrapezoidVolumeBounds > bounds
Chamber volume bounds.
Definition: Chamber.h:33
Muon::IMuonIdHelperSvc::sector
virtual int sector(const Identifier &id) const =0
return sector number 1-16, odd=large, even=small
MuonGMR4::Chamber::stationName
int stationName() const
Returns an integer representing the stationName.
Definition: Chamber.cxx:122
Muon::IMuonIdHelperSvc::issTgc
virtual bool issTgc(const Identifier &id) const =0
returns whether this is a sTGC Identifier or not
ActsTrk::GeometryContext::context
Acts::GeometryContext context() const
Definition: GeometryContext.h:46
Identifier
Definition: IdentifierFieldParser.cxx:14