CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
Functions
barrelUtil Namespace Reference

Functions

float calculatePhiWindow (float Xmax, const GeomDet &det, const TrajectoryStateOnSurface &state)
 
float computeWindowSize (const GeomDet *det, const TrajectoryStateOnSurface &tsos, const MeasurementEstimator &est)
 
bool overlap (float phi, const GeometricSearchDet &gsdet, float phiWin)
 

Function Documentation

float barrelUtil::calculatePhiWindow ( float  Xmax,
const GeomDet det,
const TrajectoryStateOnSurface state 
)
inline

Definition at line 16 of file BarrelUtil.h.

References funct::abs(), PV3DBase< T, PVType, FrameType >::barePhi(), TrajectoryStateOnSurface::globalPosition(), TrajectoryStateOnSurface::localPosition(), min(), edm::shift, GeomDet::surface(), and Surface::toGlobal().

Referenced by computeWindowSize().

17  {
18 
19  LocalPoint startPoint = state.localPosition();
20  LocalVector shift( Xmax , 0. , 0.);
21  LocalPoint shift1 = startPoint + shift;
22  LocalPoint shift2 = startPoint + (-shift);
23  //LocalPoint shift2( startPoint); //original code;
24  //shift2 -= shift;
25 
26  auto phi1 = det.surface().toGlobal(shift1).barePhi();
27  auto phi2 = det.surface().toGlobal(shift2).barePhi();
28  auto phiStart = state.globalPosition().barePhi();
29  auto phiWin = std::min(std::abs(phiStart-phi1),std::abs(phiStart-phi2));
30 
31  return phiWin;
32  }
GlobalPoint toGlobal(const Point2DBase< Scalar, LocalTag > lp) const
Definition: Surface.h:106
GlobalPoint globalPosition() const
const Plane & surface() const
The nominal surface of the GeomDet.
Definition: GeomDet.h:40
T barePhi() const
Definition: PV3DBase.h:68
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
T min(T a, T b)
Definition: MathUtil.h:58
static unsigned int const shift
float barrelUtil::computeWindowSize ( const GeomDet det,
const TrajectoryStateOnSurface tsos,
const MeasurementEstimator est 
)
inline

Definition at line 35 of file BarrelUtil.h.

References calculatePhiWindow(), MeasurementEstimator::maximalLocalDisplacement(), GeomDet::surface(), x(), and SiStripMonitorClusterAlca_cfi::xmax.

Referenced by TBPLayer::computeWindowSize().

37  {
38  auto xmax =
39  est.maximalLocalDisplacement(tsos, det->surface()).x();
40  return calculatePhiWindow( xmax, *det, tsos);
41  }
virtual Local2DVector maximalLocalDisplacement(const TrajectoryStateOnSurface &ts, const Plane &plane) const =0
const Plane & surface() const
The nominal surface of the GeomDet.
Definition: GeomDet.h:40
T x() const
Cartesian x coordinate.
float calculatePhiWindow(float Xmax, const GeomDet &det, const TrajectoryStateOnSurface &state)
Definition: BarrelUtil.h:16
bool barrelUtil::overlap ( float  phi,
const GeometricSearchDet gsdet,
float  phiWin 
)
inline

Definition at line 46 of file BarrelUtil.h.

References constexpr, Surface::phiSpan(), rangesIntersect(), and GeometricSearchDet::surface().

Referenced by TBPLayer::searchNeighbors().

46  {
47  // introduce offset (extrapolated point and true propagated point differ by 0.0003 - 0.00033,
48  // due to thickness of Rod of 1 cm)
49  constexpr float phiOffset = 0.00034; //...TOBE CHECKED LATER...
50  phiWin += phiOffset;
51 
52  // detector phi range
53  std::pair<float,float> phiRange(phi-phiWin, phi+phiWin);
54 
55  return rangesIntersect(phiRange, gsdet.surface().phiSpan(), PhiLess());
56  }
virtual const BoundSurface & surface() const =0
The surface of the GeometricSearchDet.
std::pair< float, float > const & phiSpan() const
Definition: Surface.h:123
#define constexpr
bool rangesIntersect(const Range &a, const Range &b)
Geom::Phi< T > phi() const