CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
List of all members | Public Member Functions
Chi2Strip1DEstimator Class Referencefinal

#include <Chi2Strip1DEstimator.h>

Inheritance diagram for Chi2Strip1DEstimator:
Chi2MeasurementEstimatorBase MeasurementEstimator

Public Member Functions

 Chi2Strip1DEstimator (double maxChi2, double nSigma=3.)
 
Chi2Strip1DEstimatorclone () const override
 
std::pair< bool, double > estimate (const TrajectoryStateOnSurface &, const TrackingRecHit &) const override
 
- Public Member Functions inherited from Chi2MeasurementEstimatorBase
 Chi2MeasurementEstimatorBase (double maxChi2, double nSigma=3., float maxDisp=std::numeric_limits< float >::max())
 
template<typename... Args>
 Chi2MeasurementEstimatorBase (double maxChi2, double nSigma, float maxDisp, Args &&...args)
 
double chiSquaredCut () const
 
bool estimate (const TrajectoryStateOnSurface &ts, const Plane &plane) const final
 
Local2DVector maximalLocalDisplacement (const TrajectoryStateOnSurface &ts, const Plane &plane) const final
 
double nSigmaCut () const
 
- Public Member Functions inherited from MeasurementEstimator
float maxSagitta () const
 
 MeasurementEstimator ()
 
 MeasurementEstimator (float maxSag, float minToll, float mpt)
 
float minPt2ForHitRecoveryInGluedDet () const
 
float minTolerance2 () const
 
virtual bool preFilter (const TrajectoryStateOnSurface &, OpaquePayload const &) const
 
virtual ~MeasurementEstimator ()
 

Additional Inherited Members

- Public Types inherited from MeasurementEstimator
using HitReturnType = std::pair< bool, double >
 
using Local2DVector = Vector2DBase< float, LocalTag >
 
using SurfaceReturnType = bool
 
- Protected Member Functions inherited from Chi2MeasurementEstimatorBase
std::pair< bool, double > returnIt (double est) const
 

Detailed Description

A Chi2 MeasurementEstimator that only uses the X coordinate in the measurement frame (the one perpendicular to the strip). Ported from ORCA.

Author
todorov, cerati

Definition at line 14 of file Chi2Strip1DEstimator.h.

Constructor & Destructor Documentation

Chi2Strip1DEstimator::Chi2Strip1DEstimator ( double  maxChi2,
double  nSigma = 3. 
)
inlineexplicit

Definition at line 16 of file Chi2Strip1DEstimator.h.

Referenced by clone().

Chi2MeasurementEstimatorBase(double maxChi2, double nSigma=3., float maxDisp=std::numeric_limits< float >::max())

Member Function Documentation

Chi2Strip1DEstimator* Chi2Strip1DEstimator::clone ( void  ) const
inlineoverridevirtual

Implements MeasurementEstimator.

Definition at line 20 of file Chi2Strip1DEstimator.h.

References Chi2Strip1DEstimator().

20 { return new Chi2Strip1DEstimator(*this); }
Chi2Strip1DEstimator(double maxChi2, double nSigma=3.)
pair< bool, double > Chi2Strip1DEstimator::estimate ( const TrajectoryStateOnSurface ts,
const TrackingRecHit hit 
) const
overridevirtual

Returns pair( true, value) if the TrajectoryStateOnSurface is compatible with the RecHit, and pair( false, value) if it is not compatible. The TrajectoryStateOnSurface must be on the same Surface as the RecHit. For an estimator where there is no value computed, e.g. fixed window estimator, only the first(bool) part is of interest.

Implements Chi2MeasurementEstimatorBase.

Definition at line 8 of file Chi2Strip1DEstimator.cc.

References gen::C, TrackingRecHit::detUnit(), GeomDetType::isTrackerPixel(), TrajectoryStateOnSurface::localError(), TrajectoryStateOnSurface::localPosition(), TrackingRecHit::localPosition(), TrackingRecHit::localPositionError(), visualization-live-secondInstance_cfg::m, Topology::measurementError(), Topology::measurementPosition(), LocalTrajectoryError::positionError(), dttmaxenums::R, alignCSCRings::r, GeomDet::topology(), GeomDet::type(), and cms::cuda::V.

9  {
10  if ( //hit.isMatched() ||
11  hit.detUnit()->type().isTrackerPixel())
12  return HitReturnType(false, 0.);
13 
14  const StripTopology* topology = dynamic_cast<const StripTopology*>(&(hit.detUnit()->topology()));
15 
16  double m = topology->measurementPosition(hit.localPosition()).x();
17 
18  double x = topology->measurementPosition(state.localPosition()).x();
19 
20  double V = topology->measurementError(hit.localPosition(), hit.localPositionError()).uu();
21  double C = topology->measurementError(state.localPosition(), state.localError().positionError()).uu();
22  double r = m - x;
23  double R = V + C;
24 
25  double est = r * r / R;
26 
27  return returnIt(est);
28 }
virtual const GeomDetType & type() const
Definition: GeomDet.cc:69
virtual const Topology & topology() const
Definition: GeomDet.cc:67
uint32_t T const *__restrict__ uint32_t const *__restrict__ int32_t int Histo::index_type cudaStream_t V
virtual MeasurementError measurementError(const LocalPoint &, const LocalError &) const =0
virtual MeasurementPoint measurementPosition(const LocalPoint &) const =0
bool isTrackerPixel() const
Definition: GeomDetType.cc:15
std::pair< bool, double > returnIt(double est) const
virtual LocalError localPositionError() const =0
virtual const GeomDetUnit * detUnit() const
std::pair< bool, double > HitReturnType
virtual LocalPoint localPosition() const =0