|  | ATLAS Offline Software
    | 
#include <PixelModuleDesign.h>
| Public Types | |
| enum | Axis { xAxis =0, yAxis, zAxis } | 
| Public Member Functions | |
| PixelModuleDesign (const double thickness, const int circuitsPerColumn, const int circuitsPerRow, const int cellColumnsPerCircuit, const int cellRowsPerCircuit, const int diodeColumnsPerCircuit, const int diodeRowsPerCircuit, PixelDiodeTree &&diode_tree, InDetDD::CarrierType carrierType, int readoutSide, bool is3D, InDetDD::DetectorType detectorType, PixelReadoutTechnology readoutTechnology) | |
| Constructor with parameters: local axis corresponding to eta direction local axis corresponding to phi direction local axis corresponding to depth direction thickness of silicon sensor number of circuits in one circuit column number of circuits in one circuit row number of cell columns per circuit number of cell rows per circuit number of diode columns connected to one circuit number of diode rows connected to one circuit.  More... | |
| PixelModuleDesign (const double thickness, const bool phiSymmetric, const bool etaSymmetric, const bool depthSymmetric, const int circuitsPerColumn, const int circuitsPerRow, const int cellColumnsPerCircuit, const int cellRowsPerCircuit, const int diodeColumnsPerCircuit, const int diodeRowsPerCircuit, PixelDiodeTree &&diode_tree, InDetDD::CarrierType carrierType, int readoutSide, bool is3D, InDetDD::DetectorType detectorType, PixelReadoutTechnology readoutTechnology) | |
| virtual | ~PixelModuleDesign ()=default | 
| virtual void | distanceToDetectorEdge (const SiLocalPosition &localPosition, double &etaDist, double &phiDist) const | 
| Returns distance to nearest detector active edge +ve = inside -ve = outside.  More... | |
| virtual SiDiodesParameters | parameters (const SiCellId &cellId) const | 
| readout or diode id -> position, size  More... | |
| virtual SiLocalPosition | localPositionOfCell (const SiCellId &cellId) const | 
| readout or diode id -> position.  More... | |
| virtual int | numberOfConnectedCells (const SiReadoutCellId &readoutId) const | 
| readout id -> id of connected diodes  More... | |
| virtual SiCellId | connectedCell (const SiReadoutCellId &readoutId, int number) const | 
| readout id -> id of connected diodes.  More... | |
| virtual SiCellId | gangedCell (const SiCellId &cellId) const | 
| If cell is ganged return the other cell, otherwise return an invalid id.  More... | |
| virtual SiReadoutCellId | readoutIdOfCell (const SiCellId &cellId) const | 
| diode id -> readout id  More... | |
| virtual SiReadoutCellId | readoutIdOfPosition (const SiLocalPosition &localPos) const | 
| position -> id  More... | |
| virtual SiCellId | cellIdOfPosition (const SiLocalPosition &localPos) const | 
| position -> id  More... | |
| virtual SiCellId | cellIdInRange (const SiCellId &cellId) const | 
| Check if cell is in range.  More... | |
| bool | isInsideMatrix (const SiCellId &cellId) const | 
| Return true if the given index describes a pixel of this matrix.  More... | |
| bool | isInsideMatrix (const std::array< InDetDD::PixelDiodeTree::IndexType, 2 > &idx) const | 
| Return true if the given index describes a pixel of this matrix.  More... | |
| bool | isInsideMatrix (const Amg::Vector2D &local_position) const | 
| Return true if the given position is a position within one of the pixels of this matrix.  More... | |
| virtual HepGeom::Vector3D< double > | phiMeasureSegment (const SiLocalPosition &) const | 
| Helper method for stereo angle computation.  More... | |
| virtual std::pair< SiLocalPosition, SiLocalPosition > | endsOfStrip (const SiLocalPosition &position) const | 
| Special method for SCT (irrelevant here):  More... | |
| SiLocalPosition | positionFromColumnRow (const int column, const int row) const | 
| Given row and column index of a diode, return position of diode center ALTERNATIVE/PREFERED way is to use localPositionOfCell(const SiCellId & cellId) or rawLocalPositionOfCell method in SiDetectorElement.  More... | |
| virtual void | neighboursOfCell (const SiCellId &cellId, std::vector< SiCellId > &neighbours) const | 
| Get the neighbouring diodes of a given diode: Cell for which the neighbours must be found List of cells which are neighbours of the given one.  More... | |
| double | intersectionLength (const SiCellId &diode1, const SiCellId &diode2) const | 
| Compute the intersection length of two diodes: return: the intersection length when the two diodes are projected on one of the two axis, or 0 in case of no intersection or problem input: the two diodes for which the intersection length is computed.  More... | |
| int | numberOfDiodes () const | 
| Total number of diodes:  More... | |
| int | numberOfCircuits () const | 
| Total number of circuits:  More... | |
| int | numberOfCircuitsPerColumn () const | 
| Number of circuits per column:  More... | |
| int | numberOfCircuitsPerRow () const | 
| Number of circuits per row:  More... | |
| int | columnsPerCircuit () const | 
| Number of cell columns per circuit:  More... | |
| int | rowsPerCircuit () const | 
| Number of cell rows per circuit:  More... | |
| int | columns () const | 
| Number of cell columns per module:  More... | |
| int | rows () const | 
| Number of cell rows per module:  More... | |
| virtual double | length () const | 
| Method to calculate length of a module.  More... | |
| virtual double | width () const | 
| Method to calculate average width of a module.  More... | |
| virtual double | minWidth () const | 
| Method to calculate minimum width of a module.  More... | |
| virtual double | maxWidth () const | 
| Method to calculate maximum width of a module.  More... | |
| virtual double | phiPitch () const | 
| Pitch in phi direction.  More... | |
| virtual double | phiPitch (const SiLocalPosition &localPosition) const | 
| Pitch in phi direction.  More... | |
| virtual double | etaPitch () const | 
| Pitch in eta direction.  More... | |
| double | widthFromColumnRange (const int colMin, const int colMax) const | 
| Method to calculate eta width from a column range.  More... | |
| double | widthFromRowRange (const int rowMin, const int rowMax) const | 
| Method to calculate phi width from a row range.  More... | |
| virtual bool | nearBondGap (const SiLocalPosition &localPosition, double etaTol) const | 
| Test if near bond gap within tolerances Only relevant for SCT.  More... | |
| virtual bool | swapHitPhiReadoutDirection () const | 
| Return true if hit local direction is the same as readout direction.  More... | |
| virtual bool | swapHitEtaReadoutDirection () const | 
| virtual const Trk::SurfaceBounds & | bounds () const | 
| Element boundary.  More... | |
| virtual bool | is3D () const | 
| PixelReadoutTechnology | getReadoutTechnology () const | 
| virtual DetectorType | type () const final | 
| Type of element.  More... | |
| void | addMultipleRowConnection (const int lowerRow, const std::vector< int > &connections) | 
| Add a new multiple connection for rows: lower diode row for which the connection scheme is given vector containing, for each diode, the readout cell row number to which the corresponding diode is connected.  More... | |
| std::string | debugStringRepr () const | 
| Debug string representation.  More... | |
| PixelDiodeTree::DiodeProxy | diodeProxyFromIdx (const std::array< PixelDiodeTree::IndexType, 2 > &idx) const | 
| PixelDiodeTree::DiodeProxyWithPosition | diodeProxyFromIdxCachePosition (const std::array< PixelDiodeTree::IndexType, 2 > &idx) const | 
| PixelDiodeTree::DiodeProxy | diodeProxyFromPosition (const Amg::Vector2D &pos) const | 
| virtual double | sinStripAngleReco (double phiCoord, double etaCoord) const | 
| Give strip angle in the reco frame.  More... | |
| virtual int | strip1Dim (int strip, int row) const | 
| only relevant for SCT.  More... | |
| virtual Amg::Vector3D | sensorCenter () const | 
| Return the centre of a sensor in the local reference frame.  More... | |
| virtual SiIntersect | inDetector (const SiLocalPosition &localPosition, double phiTol, double etaTol) const | 
| Test if point is in the active part of the detector with specified tolerances.  More... | |
| void | setSymmetry (bool phiSymmetric, bool etaSymmetric, bool depthSymmetric) | 
| Override default symmetries to prevent swapping of axes.  More... | |
| Axis | etaAxis () const | 
| local axis corresponding to eta direction:  More... | |
| Axis | phiAxis () const | 
| local axis corresponding to phi direction:  More... | |
| Axis | depthAxis () const | 
| local axis corresponding to depth direction:  More... | |
| double | thickness () const | 
| Method which returns thickness of the silicon wafer.  More... | |
| InDetDD::CarrierType | carrierType () const | 
| Return carrier type (ie electrons or holes)  More... | |
| bool | phiSymmetric () const | 
| bool | etaSymmetric () const | 
| bool | depthSymmetric () const | 
| int | readoutSide () const | 
| ReadoutSide.  More... | |
| virtual DetectorShape | shape () const | 
| Shape of element.  More... | |
| virtual const Amg::Transform3D | moduleShift () const | 
| Static Public Member Functions | |
| static unsigned int | getFE (const PixelDiodeTree::DiodeProxy &diode_proxy) | 
| static InDetDD::PixelDiodeType | getDiodeType (const PixelDiodeTree::DiodeProxy &diode_proxy) | 
| Private Member Functions | |
| PixelModuleDesign () | |
| PixelModuleDesign (const PixelModuleDesign &design) | |
| PixelModuleDesign & | operator= (const PixelModuleDesign &design) | 
Class used to describe the design of a module (diode segmentation and readout scheme)
Definition at line 45 of file PixelModuleDesign.h.
| 
 | inherited | 
| Enumerator | |
|---|---|
| xAxis | |
| yAxis | |
| zAxis | |
Definition at line 59 of file DetectorDesign.h.
| InDetDD::PixelModuleDesign::PixelModuleDesign | ( | const double | thickness, | 
| const int | circuitsPerColumn, | ||
| const int | circuitsPerRow, | ||
| const int | cellColumnsPerCircuit, | ||
| const int | cellRowsPerCircuit, | ||
| const int | diodeColumnsPerCircuit, | ||
| const int | diodeRowsPerCircuit, | ||
| PixelDiodeTree && | diode_tree, | ||
| InDetDD::CarrierType | carrierType, | ||
| int | readoutSide, | ||
| bool | is3D, | ||
| InDetDD::DetectorType | detectorType, | ||
| PixelReadoutTechnology | readoutTechnology | ||
| ) | 
Constructor with parameters: local axis corresponding to eta direction local axis corresponding to phi direction local axis corresponding to depth direction thickness of silicon sensor number of circuits in one circuit column number of circuits in one circuit row number of cell columns per circuit number of cell rows per circuit number of diode columns connected to one circuit number of diode rows connected to one circuit.
Definition at line 62 of file PixelModuleDesign.cxx.
| InDetDD::PixelModuleDesign::PixelModuleDesign | ( | const double | thickness, | 
| const bool | phiSymmetric, | ||
| const bool | etaSymmetric, | ||
| const bool | depthSymmetric, | ||
| const int | circuitsPerColumn, | ||
| const int | circuitsPerRow, | ||
| const int | cellColumnsPerCircuit, | ||
| const int | cellRowsPerCircuit, | ||
| const int | diodeColumnsPerCircuit, | ||
| const int | diodeRowsPerCircuit, | ||
| PixelDiodeTree && | diode_tree, | ||
| InDetDD::CarrierType | carrierType, | ||
| int | readoutSide, | ||
| bool | is3D, | ||
| InDetDD::DetectorType | detectorType, | ||
| PixelReadoutTechnology | readoutTechnology | ||
| ) | 
Definition at line 29 of file PixelModuleDesign.cxx.
| 
 | virtualdefault | 
| 
 | private | 
| 
 | private | 
| 
 | inline | 
Add a new multiple connection for rows: lower diode row for which the connection scheme is given vector containing, for each diode, the readout cell row number to which the corresponding diode is connected.
Definition at line 295 of file PixelModuleDesign.h.
| 
 | virtual | 
Element boundary.
Implements InDetDD::DetectorDesign.
Definition at line 267 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
Return carrier type (ie electrons or holes)
Definition at line 275 of file DetectorDesign.h.
Check if cell is in range.
Returns the original cellId if it is in range, otherwise it returns an invalid id.
Implements InDetDD::DetectorDesign.
Definition at line 276 of file PixelModuleDesign.cxx.
| 
 | virtual | 
position -> id
Implements InDetDD::DetectorDesign.
Definition at line 214 of file PixelModuleDesign.cxx.
| 
 | inline | 
Number of cell columns per module:
Definition at line 331 of file PixelModuleDesign.h.
| 
 | inline | 
Number of cell columns per circuit:
Definition at line 321 of file PixelModuleDesign.h.
| 
 | virtual | 
readout id -> id of connected diodes.
parameter number = 0 will refer to the primary diode and in general the cell number will be the same. NB. SiCellId cellId = connectedCell(readoutId, 0) will in general be equivalent to SiCellId cellId = readoutId
Implements InDetDD::DetectorDesign.
Definition at line 230 of file PixelModuleDesign.cxx.
| 
 | inline | 
Debug string representation.
Definition at line 395 of file PixelModuleDesign.h.
| 
 | inlineinherited | 
local axis corresponding to depth direction:
Definition at line 267 of file DetectorDesign.h.
| 
 | inlineinherited | 
Definition at line 287 of file DetectorDesign.h.
| 
 | inline | 
Definition at line 248 of file PixelModuleDesign.h.
| 
 | inline | 
Definition at line 251 of file PixelModuleDesign.h.
| 
 | inline | 
Definition at line 254 of file PixelModuleDesign.h.
| 
 | virtual | 
Returns distance to nearest detector active edge +ve = inside -ve = outside.
Implements InDetDD::DetectorDesign.
Definition at line 88 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Special method for SCT (irrelevant here):
Implements InDetDD::SiDetectorDesign.
Definition at line 135 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
local axis corresponding to eta direction:
Definition at line 259 of file DetectorDesign.h.
| 
 | virtual | 
Pitch in eta direction.
Implements InDetDD::DetectorDesign.
Definition at line 208 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
Definition at line 283 of file DetectorDesign.h.
If cell is ganged return the other cell, otherwise return an invalid id.
Implements InDetDD::SiDetectorDesign.
Definition at line 236 of file PixelModuleDesign.cxx.
| 
 | inlinestatic | 
Definition at line 261 of file PixelModuleDesign.h.
| 
 | inlinestatic | 
Definition at line 258 of file PixelModuleDesign.h.
| 
 | inline | 
Definition at line 391 of file PixelModuleDesign.h.
| 
 | virtualinherited | 
Test if point is in the active part of the detector with specified tolerances.
Reimplemented in InDetDD::SCT_ModuleSideDesign.
Definition at line 106 of file DetectorDesign.cxx.
| 
 | inline | 
Compute the intersection length of two diodes: return: the intersection length when the two diodes are projected on one of the two axis, or 0 in case of no intersection or problem input: the two diodes for which the intersection length is computed.
Definition at line 367 of file PixelModuleDesign.h.
| 
 | inlinevirtual | 
Definition at line 386 of file PixelModuleDesign.h.
| 
 | inline | 
Return true if the given position is a position within one of the pixels of this matrix.
Definition at line 407 of file PixelModuleDesign.h.
Return true if the given index describes a pixel of this matrix.
Definition at line 400 of file PixelModuleDesign.h.
| 
 | inline | 
Return true if the given index describes a pixel of this matrix.
Definition at line 404 of file PixelModuleDesign.h.
| 
 | virtual | 
Method to calculate length of a module.
Implements InDetDD::DetectorDesign.
Definition at line 142 of file PixelModuleDesign.cxx.
| 
 | virtual | 
readout or diode id -> position.
Implements InDetDD::DetectorDesign.
Definition at line 117 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Method to calculate maximum width of a module.
Implements InDetDD::DetectorDesign.
Definition at line 160 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Method to calculate minimum width of a module.
Implements InDetDD::DetectorDesign.
Definition at line 154 of file PixelModuleDesign.cxx.
| 
 | virtualinherited | 
Reimplemented in InDetDD::StripBoxDesign.
Definition at line 130 of file DetectorDesign.cxx.
| 
 | inlinevirtual | 
Test if near bond gap within tolerances Only relevant for SCT.
Always returns false for pixels.
Implements InDetDD::SiDetectorDesign.
Definition at line 341 of file PixelModuleDesign.h.
| 
 | inlinevirtual | 
Get the neighbouring diodes of a given diode: Cell for which the neighbours must be found List of cells which are neighbours of the given one.
Implements InDetDD::DetectorDesign.
Definition at line 358 of file PixelModuleDesign.h.
| 
 | inline | 
Total number of circuits:
Definition at line 306 of file PixelModuleDesign.h.
| 
 | inline | 
Number of circuits per column:
Definition at line 311 of file PixelModuleDesign.h.
| 
 | inline | 
Number of circuits per row:
Definition at line 316 of file PixelModuleDesign.h.
| 
 | virtual | 
readout id -> id of connected diodes
Implements InDetDD::DetectorDesign.
Definition at line 224 of file PixelModuleDesign.cxx.
| 
 | inline | 
Total number of diodes:
Definition at line 301 of file PixelModuleDesign.h.
| 
 | private | 
| 
 | virtual | 
readout or diode id -> position, size
Implements InDetDD::DetectorDesign.
Definition at line 107 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
local axis corresponding to phi direction:
Definition at line 263 of file DetectorDesign.h.
| 
 | virtual | 
Helper method for stereo angle computation.
Implements InDetDD::SiDetectorDesign.
Definition at line 127 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Pitch in phi direction.
Implements InDetDD::DetectorDesign.
Definition at line 192 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Pitch in phi direction.
Implements InDetDD::DetectorDesign.
Definition at line 200 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
Definition at line 279 of file DetectorDesign.h.
| SiLocalPosition InDetDD::PixelModuleDesign::positionFromColumnRow | ( | const int | column, | 
| const int | row | ||
| ) | const | 
Given row and column index of a diode, return position of diode center ALTERNATIVE/PREFERED way is to use localPositionOfCell(const SiCellId & cellId) or rawLocalPositionOfCell method in SiDetectorElement.
DEPRECATED
Definition at line 260 of file PixelModuleDesign.cxx.
| 
 | virtual | 
diode id -> readout id
Implements InDetDD::DetectorDesign.
Definition at line 242 of file PixelModuleDesign.cxx.
| 
 | virtual | 
position -> id
Implements InDetDD::DetectorDesign.
Definition at line 249 of file PixelModuleDesign.cxx.
| 
 | inlineinherited | 
ReadoutSide.
+1 = postive depth side, -1 = negative depth side.
Definition at line 291 of file DetectorDesign.h.
| 
 | inline | 
Number of cell rows per module:
Definition at line 336 of file PixelModuleDesign.h.
| 
 | inline | 
Number of cell rows per circuit:
Definition at line 326 of file PixelModuleDesign.h.
| 
 | virtualinherited | 
Return the centre of a sensor in the local reference frame.
For most designs, this is the origin of the local reference frame. For StripStereoAnnulusDesign, this is not the case (coordinate origin is "on the beamline")
Reimplemented in InDetDD::StripStereoAnnulusDesign, and InDetDD::StripAnnulusDesign.
Definition at line 60 of file DetectorDesign.cxx.
| 
 | inherited | 
Override default symmetries to prevent swapping of axes.
NB. Flags can be changed from true to false but not false to true.
Definition at line 65 of file DetectorDesign.cxx.
| 
 | virtualinherited | 
Shape of element.
Reimplemented in InDetDD::StripStereoAnnulusDesign, and InDetDD::SCT_ForwardModuleSideDesign.
Definition at line 96 of file DetectorDesign.cxx.
| 
 | inlinevirtualinherited | 
Give strip angle in the reco frame.
Reimplemented in InDetDD::StripStereoAnnulusDesign, and InDetDD::SCT_ForwardModuleSideDesign.
Definition at line 132 of file SiDetectorDesign.h.
| 
 | inlinevirtualinherited | 
only relevant for SCT.
Return strip1Dim(int strip, int row) if SCT; otherwise -1
Reimplemented in InDetDD::SCT_ModuleSideDesign, InDetDD::StripStereoAnnulusDesign, and InDetDD::StripBoxDesign.
Definition at line 136 of file SiDetectorDesign.h.
| 
 | inlinevirtual | 
Implements InDetDD::DetectorDesign.
Definition at line 352 of file PixelModuleDesign.h.
| 
 | inlinevirtual | 
Return true if hit local direction is the same as readout direction.
Implements InDetDD::DetectorDesign.
Definition at line 347 of file PixelModuleDesign.h.
| 
 | inlineinherited | 
Method which returns thickness of the silicon wafer.
Definition at line 271 of file DetectorDesign.h.
| 
 | finalvirtual | 
Type of element.
Reimplemented from InDetDD::DetectorDesign.
Definition at line 281 of file PixelModuleDesign.cxx.
| 
 | virtual | 
Method to calculate average width of a module.
Implements InDetDD::DetectorDesign.
Definition at line 148 of file PixelModuleDesign.cxx.
| double InDetDD::PixelModuleDesign::widthFromColumnRange | ( | const int | colMin, | 
| const int | colMax | ||
| ) | const | 
Method to calculate eta width from a column range.
Definition at line 167 of file PixelModuleDesign.cxx.
Method to calculate phi width from a row range.
Definition at line 179 of file PixelModuleDesign.cxx.
| 
 | private | 
Definition at line 285 of file PixelModuleDesign.h.
| 
 | privateinherited | 
Definition at line 240 of file DetectorDesign.h.
| 
 | privateinherited | 
Definition at line 238 of file DetectorDesign.h.
| 
 | privateinherited | 
Definition at line 244 of file DetectorDesign.h.
| 
 | private | 
Definition at line 286 of file PixelModuleDesign.h.
| 
 | private | 
Definition at line 283 of file PixelModuleDesign.h.
| 
 | privateinherited | 
Definition at line 236 of file DetectorDesign.h.
| 
 | privateinherited | 
Definition at line 243 of file DetectorDesign.h.
| 
 | private | 
Definition at line 288 of file PixelModuleDesign.h.
| 
 | privateinherited | 
Definition at line 237 of file DetectorDesign.h.
| 
 | privateinherited | 
Definition at line 242 of file DetectorDesign.h.
| 
 | private | 
Definition at line 284 of file PixelModuleDesign.h.
| 
 | privateinherited | 
Definition at line 246 of file DetectorDesign.h.
| 
 | private | 
Definition at line 287 of file PixelModuleDesign.h.
| 
 | privateinherited | 
Definition at line 239 of file DetectorDesign.h.
 1.8.18
 1.8.18