57 OrderedHitPairs::const_iterator ip;
60 if (pairs.empty())
return;
62 int size = thirdLayers.size();
65 for (
int il=0; il <=size-1; il++) {
66 thirdHitMap[il] = &(*theLayerCache)(thirdLayers[il], region, es);
71 if (!firstLayer || !secondLayer)
return;
77 for (ip = pairs.begin(); ip != pairs.end(); ip++) {
89 double msRPhi1 = sigma1RPhi(pt_p1p2,
line.cotLine(), 0.f);
90 double msRPhi2 = sigma2RPhi(pt_p1p2,
line.cotLine(),point1);
94 double p1_errorRPhi =
sqrt(
sqr((*ip).inner()->errorGlobalRPhi())+
sqr(msRPhi1) +
sqr(errorXY));
95 double p2_errorRPhi =
sqrt(
sqr((*ip).outer()->errorGlobalRPhi())+
sqr(msRPhi2) +
sqr(errorXY));
99 for (
int il=0; il <=size-1; il++) {
101 const DetLayer * layer = thirdLayers[il].detLayer();
104 double msRPhi3 = sigma3RPhi(pt_p1p2,
line.cotLine(),point2);
111 rRange =
Range(radius-halfThickness, radius+halfThickness);
116 float zMin = zLayer-halfThickness;
117 float zMax = zLayer+halfThickness;
121 if (zLayer * p3_a.
z() < 0)
continue;
125 double displacment = shift.
perp();
126 GlobalPoint crossing1 = predictionRPhi.crossing(rRange.min()-displacment)+shift;
127 GlobalPoint crossing2 = predictionRPhi.crossing(rRange.max()+displacment)+shift;
128 float c1_phi= crossing1.
phi();
129 float c2_phi= crossing2.
phi();
130 if (c2_phi < c1_phi)
swap(c1_phi,c2_phi);
131 if (c2_phi-c1_phi >
M_PI) { c2_phi -= 2*
M_PI;
swap(c1_phi,c2_phi); }
133 c1_phi -= extraAngle;
134 c2_phi += extraAngle;
135 vector<Hit> thirdHits = thirdHitMap[il]->
hits(c1_phi, c2_phi) ;
137 typedef vector<Hit>::const_iterator IH;
138 for (IH th=thirdHits.begin(), eh=thirdHits.end(); th < eh; ++th) {
140 double p3_errorRPhi =
sqrt(
sqr((*th)->errorGlobalRPhi()) +
sqr(msRPhi3) +
sqr(errorXY));
142 predictionRPhi.add(
p3,p3_errorRPhi);
144 double curvature = predictionRPhi.curvature();
146 ThirdHitZPrediction zPrediction( (*ip).inner()->globalPosition(),
sqrt(
sqr((*ip).inner()->errorGlobalR())+
sqr(msRPhi1/cosTheta)),
sqrt(
sqr((*ip).inner()->errorGlobalZ())+
sqr(msRPhi1/sinTheta)),
147 (*ip).outer()->globalPosition(),
sqrt(
sqr((*ip).outer()->errorGlobalR())+
sqr(msRPhi2/cosTheta)),
sqrt(
sqr((*ip).outer()->errorGlobalZ())+
sqr(msRPhi2/sinTheta)),
151 double z3Hit = (*th)->globalPosition().z();
153 Range hitZRange(z3Hit-z3HitError, z3Hit+z3HitError);
154 bool inside = hitZRange.hasIntersection(zRange);
157 bool ptCut = (predictionRPhi.curvature()-
theNSigma*predictionRPhi.errorCurvature() < curvatureMS);
159 if (inside && ptCut && chi2Cut) {
162 edm::LogError(
"TooManyTriplets")<<
" number of triples exceed maximum. no triplets produced.";
163 delete [] thirdHitMap;
168 predictionRPhi.remove(
p3,p3_errorRPhi);
172 delete [] thirdHitMap;
float originRBound() const
bounds the particle vertex in the transverse plane
std::vector< Hit > hits(float phiMin, float phiMax) const
GlobalPoint const & origin() const
PixelRecoRange< T > & sort()
virtual Location location() const =0
Which part of the detector (barrel, endcap)
Geom::Phi< T > phi() const
Global3DPoint GlobalPoint
const Bounds & bounds() const
virtual const BoundCylinder & specificSurface() const final
Extension of the interface.
void swap(Association< C > &lhs, Association< C > &rhs)
const unsigned int theMaxElement
T inversePt(T curvature, const edm::EventSetup &iSetup)
T curvature(T InversePt, const edm::EventSetup &iSetup)
float extraHitRZtolerance
SeedingHitSet::ConstRecHitPointer Hit
BaseTrackerRecHit const * Hit
float extraHitPhiToleranceForPreFiltering
PixelRecoRange< float > Range
std::unique_ptr< HitPairGeneratorFromLayerPair > thePairGenerator
virtual float thickness() const =0
virtual const Surface::PositionType & position() const
Returns position of the surface.
float ptMin() const
minimal pt of interest
const BoundSurface & surface() const final
The surface of the GeometricSearchDet.
static unsigned int const shift
const BoundSurface & surface() const final
GeometricSearchDet interface.