49 std::vector<float>
x,
y, gz;
52 for (
int i = 0;
i < 6; ++
i) {
60 for (ChamberHitContainer::const_iterator it = rechits.begin(); it != rechits.end(); ++it) {
63 int l_id =
id.
layer();
69 x[l_id - 1] += lp.
x();
70 y[l_id - 1] += lp.
y();
71 gz[l_id - 1] += gp.
z();
75 float avgChamberX = 0.;
76 float avgChamberY = 0.;
79 for (
unsigned i = 0;
i < 6; ++
i) {
91 avgChamberX = avgChamberX / n_lay;
92 avgChamberY = avgChamberY / n_lay;
98 LocalPoint lpCOM(avgChamberX, avgChamberY, 0.);
102 float Gdxdz = gpCOM.
x() / gpCOM.
z();
103 float Gdydz = gpCOM.
y() / gpCOM.
z();
107 std::vector<LocalPoint> layerPoints;
109 for (
size_t i = 0;
i != 6; ++
i) {
114 float layer_Z = gp.
z();
117 float layer_X = Gdxdz * layer_Z;
118 float layer_Y = Gdydz * layer_Z;
122 float layerX = Lintersect.
x();
123 float layerY = Lintersect.
y();
124 float layerZ = Lintersect.
z();
125 LocalPoint layerPoint(layerX, layerY, layerZ);
126 layerPoints.push_back(layerPoint);
129 std::vector<float> r_closest;
131 for (
size_t i = 0;
i != 6; ++
i) {
133 r_closest.push_back(9999.);
139 for (ChamberHitContainer::const_iterator it = rechits.begin(); it != rechits.end(); ++it) {
147 float d_x = lp.
x() - layerPoints[layId - 1].x();
148 float d_y = lp.
y() - layerPoints[layId - 1].y();
152 if (fabs(diff.
mag()) < r_closest[layId - 1]) {
153 r_closest[layId - 1] = fabs(diff.
mag());
164 for (ChamberHitContainer::const_iterator it = rechits.begin(); it != rechits.end(); ++it) {
168 if (idx ==
id[layId - 1])
179 }
else if (gz[0] < 0.) {
193 for (ChamberHitContainer::const_iterator it = rechits.begin(); it != rechits.end(); it++) {
208 double protoTheta = protoGlobalDir.
theta();
209 double protoPhi = protoGlobalDir.
phi();
210 double simTheta = gvCOM.theta();
211 double simPhi = gvCOM.phi();
213 float dTheta = fabs(protoTheta - simTheta);
214 float dPhi = fabs(protoPhi - simPhi);
221 double theFlag = -1.;
244 double Hphi = Hgp.
phi();
254 double Sphi = Sgp.
phi();
257 double R =
sqrt(Sgp.
x() * Sgp.
x() + Sgp.
y() * Sgp.
y());
260 if (deltaPhi > 2. *
M_PI)
261 deltaPhi -= 2. *
M_PI;
262 if (deltaPhi < -2. *
M_PI)
263 deltaPhi += 2. *
M_PI;
304 ChamberHitContainer::iterator it;
306 if ((*it)->cscDetId().layer() ==
layer) {
338 float maxResidual = 0.;
339 float sumResidual = 0.;
342 ChamberHitContainer::iterator ih;
343 ChamberHitContainer::iterator ibad =
protoSegment.end();
360 sumResidual += residual;
362 if (residual > maxResidual) {
363 maxResidual = residual;
368 float corrAvgResidual = (sumResidual - maxResidual) / (nHits - 1);
CSCSetOfHits hits(void) const
CSCDetId cscDetId() const
void updateParameters(void)
LocalVector localdir() const
void compareProtoSegment(const CSCRecHit2D *h, int layer)
uint16_t *__restrict__ id
bool isHitNearSegment(const CSCRecHit2D *h) const
Utility functions.
virtual ~CSCSegAlgoShowering()
Destructor.
CSCSegment showerSeg(const CSCChamber *aChamber, const ChamberHitContainer &rechits)
GlobalPoint toGlobal(const Local2DPoint &lp) const
Conversion to the global R.F. from the R.F. of the GeomDet.
Geom::Phi< T > phi() const
float Rdev(float x, float y, float z) const
LocalPoint toLocal(const GlobalPoint &gp) const
Conversion to the R.F. of the GeomDet.
constexpr std::array< uint8_t, layerIndexSize > layer
Geom::Theta< T > theta() const
bool addHit(const CSCRecHit2D *hit, int layer)
CSCSegAlgoShowering(const edm::ParameterSet &ps)
Constructor.
const CSCLayer * layer(CSCDetId id) const
Return the layer corresponding to the given id.
std::vector< const CSCRecHit2D * > ChamberHitContainer
float xfit(float z) const
LocalPoint localPosition() const override
AlgebraicSymMatrix covarianceMatrix(void)
T getParameter(std::string const &) const
caConstants::TupleMultiplicity const CAHitNtupletGeneratorKernelsGPU::HitToTuple const cms::cuda::AtomicPairCounter GPUCACell const *__restrict__ uint32_t const *__restrict__ gpuPixelDoublets::CellNeighborsVector const gpuPixelDoublets::CellTracksVector const GPUCACell::OuterHitOfCell const int32_t nHits
LocalPoint intercept() const
The Signals That Services Can Subscribe To This is based on ActivityRegistry h
Helper function to determine trigger accepts.
const CSCChamber * theChamber
ChamberHitContainer protoSegment
void pruneFromResidual(void)
float yfit(float z) const