1 #ifndef RecoPixelVertexing_PixelTrackFitting_interface_BrokenLine_h
2 #define RecoPixelVertexing_PixelTrackFitting_interface_BrokenLine_h
4 #include <Eigen/Eigenvalues>
58 constexpr
double inv_X0 = 0.06 / 16.;
64 constexpr
double geometry_factor = 0.7;
102 using scalar = std::remove_reference<decltype(circle.
par(0))>::
type;
114 scalar tempSmallU = 1 + rho * dee;
122 scalar tempV = 1. + rho * deltaOrth;
124 scalar mu = 1. / (tempU * (1. + tempU)) + rho * lambda;
127 2. *
mu * tempSmallU * deltaPara, 2. *
mu * tempV,
mu * zeta - lambda * tempA, 0, 0, 1.;
131 circle.
par(0) = atan2(tempB, tempC);
133 circle.
par(1) = tempA / (1 + tempU);
138 circle.
cov = jacobian * circle.
cov * jacobian.transpose();
149 template <
typename M3xN,
typename V4,
int n>
157 dVec =
hits.block(0, 1, 2, 1) -
hits.block(0, 0, 2, 1);
158 eVec =
hits.block(0,
n - 1, 2, 1) -
hits.block(0,
n - 2, 2, 1);
167 eVec = -fast_fit(2) * fast_fit.head(2) / fast_fit.head(2).norm();
168 for (u_int
i = 0;
i <
n;
i++) {
169 dVec =
results.radii.block(0,
i, 2, 1);
177 for (u_int
i = 0;
i <
n;
i++) {
179 pointsSZ(1,
i) = zVec(
i);
180 pointsSZ.block(0,
i, 2, 1) = rotMat * pointsSZ.block(0,
i, 2, 1);
182 results.sTotal = pointsSZ.block(0, 0, 1,
n).transpose();
183 results.zInSZplane = pointsSZ.block(1, 0, 1,
n).transpose();
187 for (u_int
i = 1;
i <
n - 1;
i++) {
210 for (u_int
i = 0;
i <
n;
i++) {
214 if (
i > 0 &&
i <
n - 1)
217 ((sTotal(
i + 1) - sTotal(
i)) * (sTotal(
i) - sTotal(
i - 1))));
221 if (
i > 0 &&
i <
n - 1)
223 1. / (varBeta(
i) * (sTotal(
i + 1) - sTotal(
i))) *
224 (-(sTotal(
i + 1) - sTotal(
i - 1)) / ((sTotal(
i + 1) - sTotal(
i)) * (sTotal(
i) - sTotal(
i - 1))));
227 1. / (varBeta(
i + 1) * (sTotal(
i + 1) - sTotal(
i))) *
228 (-(sTotal(
i + 2) - sTotal(
i)) / ((sTotal(
i + 2) - sTotal(
i + 1)) * (sTotal(
i + 1) - sTotal(
i))));
231 c_uMat(
i,
i + 2) = 1. / (varBeta(
i + 1) * (sTotal(
i + 2) - sTotal(
i + 1)) * (sTotal(
i + 1) - sTotal(
i)));
235 return c_uMat + c_uMat.transpose();
248 template <
typename M3xN,
typename V4>
250 constexpr uint32_t
n = M3xN::ColsAtCompileTime;
257 result(0) =
hits(0, 0) - (
a(1) *
c.squaredNorm() +
c(1) *
a.squaredNorm()) *
tmp;
258 result(1) =
hits(1, 0) + (
a(0) *
c.squaredNorm() +
c(0) *
a.squaredNorm()) *
tmp;
295 template <
typename M3xN,
typename M6xN,
typename V4,
int n>
303 auto& radii =
data.radii;
304 const auto& sTransverse =
data.sTransverse;
305 const auto& sTotal =
data.sTotal;
306 auto& zInSZplane =
data.zInSZplane;
307 auto& varBeta =
data.varBeta;
308 const double slope = -circle_results.
qCharge / fast_fit(3);
311 for (u_int
i = 0;
i <
n;
i++) {
312 zInSZplane(
i) = radii.block(0,
i, 2, 1).norm() - fast_fit(2);
318 for (u_int
i = 0;
i <
n;
i++) {
319 vMat(0, 0) = hits_ge.col(
i)[0];
320 vMat(0, 1) = vMat(1, 0) = hits_ge.col(
i)[1];
321 vMat(1, 1) = hits_ge.col(
i)[2];
324 1. / ((rotMat * vMat * rotMat.transpose())(1, 1));
329 for (u_int
i = 0;
i <
n;
i++) {
330 r_uVec(
i) = weightsVec(
i) * zInSZplane(
i);
334 c_uMat.block(0, 0,
n,
n) =
matrixC_u(weightsVec, sTransverse, varBeta);
337 for (u_int
i = 0;
i <
n;
i++) {
339 if (
i > 0 &&
i <
n - 1) {
341 -(sTransverse(
i + 1) - sTransverse(
i - 1)) * (sTransverse(
i + 1) - sTransverse(
i - 1)) /
342 (2. * varBeta(
i) * (sTransverse(
i + 1) - sTransverse(
i)) * (sTransverse(
i) - sTransverse(
i - 1)));
346 (sTransverse(
i) - sTransverse(
i - 2)) / (2. * varBeta(
i - 1) * (sTransverse(
i) - sTransverse(
i - 1)));
350 (sTransverse(
i + 2) - sTransverse(
i)) / (2. * varBeta(
i + 1) * (sTransverse(
i + 1) - sTransverse(
i)));
352 c_uMat(
n,
i) = c_uMat(
i,
n);
353 if (
i > 0 &&
i <
n - 1)
358 std::cout <<
"CU5\n" << c_uMat << std::endl;
363 std::cout <<
"I5\n" << iMat << std::endl;
370 radii.block(0, 0, 2, 1) /= radii.block(0, 0, 2, 1).norm();
371 radii.block(0, 1, 2, 1) /= radii.block(0, 1, 2, 1).norm();
375 auto eMinusd = eVec - dVec;
376 auto eMinusd2 = eMinusd.squaredNorm();
377 auto tmp1 = 1. / eMinusd2;
380 circle_results.
par << atan2(eMinusd(1), eMinusd(0)), circle_results.
qCharge * (tmp2 - fast_fit(2)),
381 circle_results.
qCharge * (1. / fast_fit(2) + uVec(
n));
386 jacobian << (radii(1, 0) * eMinusd(0) - eMinusd(1) * radii(0, 0)) * tmp1,
387 (radii(1, 1) * eMinusd(0) - eMinusd(1) * radii(0, 1)) * tmp1, 0,
388 circle_results.
qCharge * (eMinusd(0) * radii(0, 0) + eMinusd(1) * radii(1, 0)) * tmp2,
389 circle_results.
qCharge * (eMinusd(0) * radii(0, 1) + eMinusd(1) * radii(1, 1)) * tmp2, 0, 0, 0,
392 circle_results.
cov << iMat(0, 0), iMat(0, 1), iMat(0,
n), iMat(1, 0), iMat(1, 1), iMat(1,
n), iMat(
n, 0),
393 iMat(
n, 1), iMat(
n,
n);
395 circle_results.
cov = jacobian * circle_results.
cov * jacobian.transpose();
400 circle_results.
cov(0, 0) +=
408 circle_results.
chi2 = 0;
409 for (u_int
i = 0;
i <
n;
i++) {
411 if (
i > 0 &&
i <
n - 1)
412 circle_results.
chi2 +=
414 uVec(
i) * (sTransverse(
i + 1) - sTransverse(
i - 1)) /
415 ((sTransverse(
i + 1) - sTransverse(
i)) * (sTransverse(
i) - sTransverse(
i - 1))) +
416 uVec(
i + 1) / (sTransverse(
i + 1) - sTransverse(
i)) +
417 (sTransverse(
i + 1) - sTransverse(
i - 1)) * uVec(
n) / 2) /
444 template <
typename V4,
typename M6xN,
int n>
450 const auto& radii =
data.radii;
451 const auto& sTotal =
data.sTotal;
452 const auto& zInSZplane =
data.zInSZplane;
453 const auto& varBeta =
data.varBeta;
455 const double slope = -
data.qCharge / fast_fit(3);
460 riemannFit::Matrix2x3d::Zero();
462 for (u_int
i = 0;
i <
n;
i++) {
463 vMat(0, 0) = hits_ge.col(
i)[0];
464 vMat(0, 1) = vMat(1, 0) = hits_ge.col(
i)[1];
465 vMat(0, 2) = vMat(2, 0) = hits_ge.col(
i)[3];
466 vMat(1, 1) = hits_ge.col(
i)[2];
467 vMat(2, 1) = vMat(1, 2) = hits_ge.col(
i)[4];
468 vMat(2, 2) = hits_ge.col(
i)[5];
469 auto tmp = 1. / radii.block(0,
i, 2, 1).norm();
470 jacobXYZtosZ(0, 0) = radii(1,
i) *
tmp;
471 jacobXYZtosZ(0, 1) = -radii(0,
i) *
tmp;
472 jacobXYZtosZ(1, 2) = 1.;
473 weights(
i) = 1. / ((rotMat * jacobXYZtosZ * vMat * jacobXYZtosZ.transpose() * rotMat.transpose())(
478 for (u_int
i = 0;
i <
n;
i++) {
487 std::cout <<
"I4\n" << iMat << std::endl;
493 line_results.
par << (uVec(1) - uVec(0)) / (sTotal(1) - sTotal(0)), uVec(0);
494 auto idiff = 1. / (sTotal(1) - sTotal(0));
495 line_results.
cov << (iMat(0, 0) - 2 * iMat(0, 1) + iMat(1, 1)) *
riemannFit::sqr(idiff) +
497 (iMat(0, 1) - iMat(0, 0)) * idiff, (iMat(0, 1) - iMat(0, 0)) * idiff, iMat(0, 0);
503 jacobian(1, 0) = -sTotal(0);
505 line_results.
par(1) += -line_results.
par(0) * sTotal(0);
506 line_results.
cov = jacobian * line_results.
cov * jacobian.transpose();
509 auto tmp = rotMat(0, 0) - line_results.
par(0) * rotMat(0, 1);
510 jacobian(1, 1) = 1. /
tmp;
511 jacobian(0, 0) = jacobian(1, 1) * jacobian(1, 1);
513 jacobian(1, 0) = line_results.
par(1) * rotMat(0, 1) * jacobian(0, 0);
514 line_results.
par(1) = line_results.
par(1) * jacobian(1, 1);
515 line_results.
par(0) = (rotMat(0, 1) + line_results.
par(0) * rotMat(0, 0)) * jacobian(1, 1);
516 line_results.
cov = jacobian * line_results.
cov * jacobian.transpose();
519 line_results.
chi2 = 0;
520 for (u_int
i = 0;
i <
n;
i++) {
522 if (
i > 0 &&
i <
n - 1)
524 uVec(
i) * (sTotal(
i + 1) - sTotal(
i - 1)) /
525 ((sTotal(
i + 1) - sTotal(
i)) * (sTotal(
i) - sTotal(
i - 1))) +
526 uVec(
i + 1) / (sTotal(
i + 1) - sTotal(
i))) /
567 const Eigen::Matrix<float, 6, 4>& hits_ge,
583 jacobian << 1., 0, 0, 0, 1., 0, 0, 0,
586 circle.
cov = jacobian * circle.
cov * jacobian.transpose();
589 helix.
cov = riemannFit::MatrixXd::Zero(5, 5);
590 helix.
cov.block(0, 0, 3, 3) = circle.
cov;
591 helix.
cov.block(3, 3, 2, 2) =
line.cov;
601 #endif // RecoPixelVertexing_PixelTrackFitting_interface_BrokenLine_h