Loading [MathJax]/jax/output/SVG/config.js
 |
ATLAS Offline Software
|
Go to the documentation of this file.
24 const double halfHeight1,
26 const double halfHeight2,
29 const int nCrystals ) :
31 m_halfHeight1(halfHeight1),
33 m_halfHeight2(halfHeight2),
36 m_nCrystals(nCrystals),
37 m_leftSide(
step*strips*(-0.5)),
38 m_rightSide(
step*strips*0.5),
39 m_upperSide1(radius1+halfHeight1),
40 m_lowerSide1(radius1-halfHeight1),
41 m_upperSide2(radius2+halfHeight2),
42 m_lowerSide2(radius2-halfHeight2)
86 double & etaDist,
double & phiDist)
const
111 bool checkBondGap)
const
113 double xEta = chargePos.
xEta();
114 double xPhi = chargePos.
xPhi();
126 return (std::abs(xPhi) < edge);
134 bool conditionTheta=
false;
135 bool conditionEtaOne=
false;
136 bool conditionEtaTwo=
false;
137 double polarR = polarPos.
r();
138 double polarTheta = polarPos.
theta();
139 double cosPolarTheta =
cos(polarTheta);
144 conditionEtaOne=
true;
147 conditionEtaTwo=
true;
150 return (conditionEtaOne || conditionEtaTwo) && conditionTheta;
157 return 2.0*polarPos.
r()*std::abs(
sin(
m_step*0.5));
166 if (polarPos.
theta()>0) stripIndex =
168 else stripIndex =
static_cast<int>(polarPos.
theta()/
m_step-1);
169 const double thetaStrip = (stripIndex+0.5)*
m_step;
170 const double pitch = 2.0*polarPos.
r()*std::abs(
sin(
m_step*0.5));
171 return polarPos.
r()*std::abs(
sin(polarPos.
theta()-thetaStrip))/pitch;
double m_halfHeight2
outer crystal (if present) half height
double m_upperSide1
upper side of crystal 1
double m_leftSide
left border of module in angle
double theta() const
theta coordinate of point:
SCT_ForwardModuleSideGeometry()
double m_halfLength
top = +halfLength, bot = -halfLength
double deadAreaUpperBoundary() const
give upper boundary of dead area
double minWidth() const
Method to calculate minimum width of a module.
double deadAreaLowerBoundary() const
give lower boundary of dead area
int m_strips
number of strips (same for both crystals)
double m_deadRegionLower
relative to center of detector.
double m_radius
r from nominal element center to beam
double deadAreaLength() const
give length of dead area
double xPhi() const
position along phi direction:
double r() const
r coordinate of point:
double xEta() const
position along eta direction:
void distanceToDetectorEdge(const SiLocalPosition &localPosition, const SCT_ForwardPolarPosition &polarPos, double &etaDist, double &phiDist) const
double m_halfHeight1
inner crystal half height
bool inActiveArea(const SiLocalPosition &chargePosition, bool checkBondGap=true) const
check if position is in active area
double m_upperSide2
upper side of crystal 2
double stripPitch(const SCT_ForwardPolarPosition &polarPos) const
give the strip pitch (dependence on position needed for forward)
double length() const
Method to calculate length of a module.
double m_lowerSide1
lower side of crystal 1
double width() const
Method to calculate average width of a module.
double scaledDistanceToNearestDiode(const SCT_ForwardPolarPosition &polarPos) const
give distance to the nearest diode in units of pitch, from 0.0 to 0.5, this method should be fast as ...
double m_radius1
r from inner crystal center to beam
double m_deadRegionUpper
relative to center of detector.
bool nearBondGap(const SiLocalPosition &localPosition, double etaTol) const
Test if near bond gap within tolerances.
int m_nCrystals
number of crystals per module side
double m_step
strip step in angle (same for both crystals)
double m_tangent
tan(theta) at edge = (halfWidth) / (radius)
double m_lowerSide2
lower side of crystal 2
double maxWidth() const
Method to calculate maximum width of a module.
double m_rightSide
right border of module in angle
double m_radius2
r from outer crystal (if present) center to beam