18#ifndef GPUCA_GPUCODE_DEVICE
22#ifndef GPUCA_ALIGPUCODE
23#include <fmt/printf.h>
31template <
typename value_T>
46template <
typename value_T>
53 if (gpu::CAMath::Abs(dx) < constants::math::Almost0) {
56 value_t crv = this->getCurvature(bz);
59 if ((gpu::CAMath::Abs(
f1) > constants::math::Almost1) || (gpu::CAMath::Abs(
f2) > constants::math::Almost1)) {
62 value_t r1 = gpu::CAMath::Sqrt((1.f -
f1) * (1.f +
f1));
63 if (gpu::CAMath::Abs(r1) < constants::math::Almost0) {
66 value_t r2 = gpu::CAMath::Sqrt((1.f -
f2) * (1.f +
f2));
67 if (gpu::CAMath::Abs(r2) < constants::math::Almost0) {
70 double r1pr2Inv = 1. / (r1 + r2);
71 double dy2dx = (
f1 +
f2) * r1pr2Inv;
72 bool arcz = gpu::CAMath::Abs(x2r) > 0.05f;
83 auto arg = r1 *
f2 - r2 *
f1;
84 if (gpu::CAMath::Abs(arg) > constants::math::Almost1) {
87 value_t rot = gpu::CAMath::ASin(arg);
90 rot = constants::math::PI - rot;
92 rot = -constants::math::PI - rot;
95 dP[
kZ] = this->getTgl() / crv * rot;
97 dP[
kZ] = dx * (r2 +
f2 * dy2dx) * this->getTgl();
103 this->updateParams(dP);
111 value_t kb = bz * constants::math::B2C;
112 double r2inv = 1. / r2, r1inv = 1. / r1;
113 double dx2r1pr2 = dx * r1pr2Inv;
115 double hh = dx2r1pr2 * r2inv * (1. + r1 * r2 +
f1 *
f2), jj = dx * (dy2dx -
f2 * r2inv);
116 double f02 = hh * r1inv;
117 double f04 = hh * dx2r1pr2 * kb;
118 double f24 = dx * kb;
119 double f12 = this->getTgl() * (f02 *
f2 + jj);
120 double f13 = dx * (r2 +
f2 * dy2dx);
121 double f14 = this->getTgl() * (f04 *
f2 + jj * f24);
124 double b00 = f02 * c20 + f04 * c40, b01 = f12 * c20 + f14 * c40 + f13 * c30;
125 double b02 = f24 * c40;
126 double b10 = f02 * c21 + f04 * c41, b11 = f12 * c21 + f14 * c41 + f13 * c31;
127 double b12 = f24 * c41;
128 double b20 = f02 * c22 + f04 * c42, b21 = f12 * c22 + f14 * c42 + f13 * c32;
129 double b22 = f24 * c42;
130 double b40 = f02 * c42 + f04 * c44, b41 = f12 * c42 + f14 * c44 + f13 * c43;
131 double b42 = f24 * c44;
132 double b30 = f02 * c32 + f04 * c43, b31 = f12 * c32 + f14 * c43 + f13 * c33;
133 double b32 = f24 * c43;
136 double a00 = f02 * b20 + f04 * b40, a01 = f02 * b21 + f04 * b41, a02 = f02 * b22 + f04 * b42;
137 double a11 = f12 * b21 + f14 * b41 + f13 * b31, a12 = f12 * b22 + f14 * b42 + f13 * b32;
138 double a22 = f24 * b42;
141 c00 += b00 + b00 + a00;
142 c10 += b10 + b01 + a01;
143 c20 += b20 + b02 + a02;
146 c11 += b11 + b11 + a11;
147 c21 += b21 + b12 + a12;
150 c22 += b22 + b22 + a22;
160template <
typename value_T>
166 if (this->getAbsCharge() == 0) {
170 if (gpu::CAMath::Abs(dx) < constants::math::Almost0) {
177 if (!linRef1.propagateTo(xk, bz)) {
180 value_t kb = bz * constants::math::B2C;
182 double snpRef0 = linRef0.getSnp(), cspRef0 = gpu::CAMath::Sqrt((1 - snpRef0) * (1 + snpRef0));
183 double snpRef1 = linRef1.getSnp(), cspRef1 = gpu::CAMath::Sqrt((1 - snpRef1) * (1 + snpRef1));
184 double cspRef0Inv = 1 / cspRef0, cspRef1Inv = 1 / cspRef1,
cc = cspRef0 + cspRef1, ccInv = 1 /
cc, dy2dx = (snpRef0 + snpRef1) * ccInv;
185 double dxccInv = dx * ccInv, hh = dxccInv * cspRef1Inv * (1 + cspRef0 * cspRef1 + snpRef0 * snpRef1), jj = dx * (dy2dx - snpRef1 * cspRef1Inv);
187 double f02 = hh * cspRef0Inv;
188 double f04 = hh * dxccInv * kb;
189 double f24 = dx * kb;
190 double f12 = linRef0.getTgl() * (f02 * snpRef1 + jj);
191 double f13 = dx * (cspRef1 + snpRef1 * dy2dx);
192 double f14 = linRef0.getTgl() * (f04 * snpRef1 + jj * f24);
196 for (
int i = 0;
i < 5;
i++) {
197 diff[
i] = this->getParam(
i) - linRef0.getParam(
i);
200 if (gpu::CAMath::Abs(snpUpd) > constants::math::Almost1) {
205 this->setY(linRef1.getY() + diff[
kY] + f02 * diff[
kSnp] + f04 * diff[
kQ2Pt]);
206 this->setZ(linRef1.getZ() + diff[
kZ] + f13 * diff[
kTgl] + f14 * diff[
kQ2Pt]);
207 this->setSnp(snpUpd);
208 this->setTgl(linRef1.getTgl() + diff[
kTgl]);
209 this->setQ2Pt(linRef1.getQ2Pt() + diff[
kQ2Pt]);
217 double b00 = f02 * c20 + f04 * c40, b01 = f12 * c20 + f14 * c40 + f13 * c30;
218 double b02 = f24 * c40;
219 double b10 = f02 * c21 + f04 * c41, b11 = f12 * c21 + f14 * c41 + f13 * c31;
220 double b12 = f24 * c41;
221 double b20 = f02 * c22 + f04 * c42, b21 = f12 * c22 + f14 * c42 + f13 * c32;
222 double b22 = f24 * c42;
223 double b40 = f02 * c42 + f04 * c44, b41 = f12 * c42 + f14 * c44 + f13 * c43;
224 double b42 = f24 * c44;
225 double b30 = f02 * c32 + f04 * c43, b31 = f12 * c32 + f14 * c43 + f13 * c33;
226 double b32 = f24 * c43;
229 double a00 = f02 * b20 + f04 * b40, a01 = f02 * b21 + f04 * b41, a02 = f02 * b22 + f04 * b42;
230 double a11 = f12 * b21 + f14 * b41 + f13 * b31, a12 = f12 * b22 + f14 * b42 + f13 * b32;
231 double a22 = f24 * b42;
234 c00 += b00 + b00 + a00;
235 c10 += b10 + b01 + a01;
236 c20 += b20 + b02 + a02;
239 c11 += b11 + b11 + a11;
240 c21 += b21 + b12 + a12;
243 c22 += b22 + b22 + a22;
253template <
typename value_T>
261template <
typename value_T>
265 if (gpu::CAMath::Abs(this->getSnp()) > constants::math::Almost1) {
266 LOGP(
debug,
"Precondition is not satisfied: |sin(phi)|>1 ! {:f}", this->getSnp());
270 math_utils::detail::bringToPMPi<value_t>(
alpha);
273 math_utils::detail::sincos(
alpha - this->getAlpha(), sa, ca);
274 value_t snp = this->getSnp(), csp = gpu::CAMath::Sqrt((1.f - snp) * (1.f + snp));
277 if ((csp * ca + snp * sa) < 0) {
283 value_t updSnp = snp * ca - csp * sa;
284 if (gpu::CAMath::Abs(updSnp) > constants::math::Almost1) {
285 LOGP(
debug,
"Rotation failed: new snp {:.2f}", updSnp);
289 this->setAlpha(
alpha);
290 this->setX(xold * ca + yold * sa);
291 this->setY(-xold * sa + yold * ca);
292 this->setSnp(updSnp);
294 if (gpu::CAMath::Abs(csp) < constants::math::Almost0) {
295 LOGP(
debug,
"Too small cosine value {:f}", csp);
296 csp = constants::math::Almost0;
316template <
typename value_T>
321 if (gpu::CAMath::Abs(this->getSnp()) > constants::math::Almost1) {
322 LOGP(
debug,
"Precondition is not satisfied: |sin(phi)|>1 ! {:f}", this->getSnp());
326 math_utils::detail::bringToPMPi<value_t>(
alpha);
331 if (!linRef1.rotateParam(
alpha, ca, sa)) {
336 if (!linRef1.propagateParamTo(trackX, bz)) {
341 value_t snp = this->getSnp(), csp = gpu::CAMath::Sqrt((1.f - snp) * (1.f + snp)), updSnp = snp * ca - csp * sa;
342 if ((csp * ca + snp * sa) < 0 || gpu::CAMath::Abs(updSnp) > constants::math::Almost1) {
346 this->setY(-sa * this->
getX() + ca * this->
getY());
348 this->setSnp(updSnp);
349 this->setAlpha(
alpha);
352 value_t snpRef0 = linRef0.getSnp(), cspRef0 = gpu::CAMath::Sqrt((
value_t(1) - snpRef0) * (
value_t(1) + snpRef0));
353 value_t snpRef1 = linRef1.getSnp(), cspRef1 = ca * cspRef0 + sa * snpRef0;
376 auto cspRef1Inv =
value_t(1) / cspRef1;
377 auto j3 = -snpRef1 * cspRef1Inv;
378 auto j4 = -linRef1.getTgl() * cspRef1Inv;
379 auto j5 = linRef1.getCurvature(bz);
386 auto hXSigY = cXSigY + cSigX2 * j3;
387 auto hXSigZ = cXSigZ + cSigX2 * j4;
388 auto hXSigSnp = cXSigSnp + cSigX2 * j5;
390 mC[
kSigY2] += j3 * (cXSigY + hXSigY);
391 mC[
kSigZ2] += j4 * (cXSigZ + hXSigZ);
392 mC[
kSigSnpY] += cXSigSnp * j3 + hXSigY * j5;
393 mC[
kSigSnp2] += j5 * (cXSigSnp + hXSigSnp);
398 mC[
kSigZY] += cXSigZ * j3 + hXSigY * j4;
399 mC[
kSigSnpZ] += cXSigSnp * j4 + hXSigZ * j5;
411template <
typename value_T>
415 value_t sn, cs, alp = this->getAlpha();
416 o2::math_utils::detail::sincos(alp, sn, cs);
417 value_t x = this->
getX(),
y = this->
getY(), snp = this->getSnp(), csp = gpu::CAMath::Sqrt((1.f - snp) * (1.f + snp));
418 value_t xv = vtx.getX() * cs + vtx.getY() * sn, yv = -vtx.getX() * sn + vtx.getY() * cs, zv = vtx.getZ();
422 value_t d = gpu::CAMath::Abs(
x * snp -
y * csp);
430 value_t crv = this->getCurvature(
b);
431 value_t tgfv = -(crv *
x - snp) / (crv *
y + csp);
432 sn = tgfv / gpu::CAMath::Sqrt(1.f + tgfv * tgfv);
433 cs = gpu::CAMath::Sqrt((1.f - sn) * (1.f + sn));
434 cs = (gpu::CAMath::Abs(tgfv) > constants::math::Almost0) ? sn / tgfv : constants::math::
Almost1;
436 x = xv * cs + yv * sn;
437 yv = -xv * sn + yv * cs;
441 alp += gpu::CAMath::ASin(sn);
442 if (!tmpT.rotate(alp) || !tmpT.propagateTo(xv,
b)) {
443#if !defined(GPUCA_ALIGPUCODE)
444 LOG(
debug) <<
"failed to propagate to alpha=" << alp <<
" X=" << xv << vtx <<
" | Track is: " << tmpT.asString();
454 o2::math_utils::detail::sincos(alp, sn, cs);
455 auto s2ylocvtx = vtx.getSigmaX2() * sn * sn + vtx.getSigmaY2() * cs * cs - 2. * vtx.getSigmaXY() * cs * sn;
456 dca->set(this->
getY() - yv, this->getZ() - zv, getSigmaY2() + s2ylocvtx, getSigmaZY(), getSigmaZ2() + vtx.getSigmaZ2());
462template <
typename value_T>
471template <
typename value_T>
483 constexpr value_t kSafe = 1e-5f;
484 value_t radPos2 = xyz[0] * xyz[0] + xyz[1] * xyz[1];
486 if (sectorAlpha || radPos2 < 1) {
487 alp = gpu::CAMath::ATan2(pxpypz[1], pxpypz[0]);
489 alp = gpu::CAMath::ATan2(xyz[1], xyz[0]);
492 alp = math_utils::detail::angle2Alpha<value_t>(alp);
496 math_utils::detail::sincos(alp, sn, cs);
498 if (cs * pxpypz[0] + sn * pxpypz[1] < 0) {
499 LOG(
debug) <<
"alpha from phiPos() will invalidate this track parameters, overriding to alpha from phi()";
500 alp = gpu::CAMath::ATan2(pxpypz[1], pxpypz[0]);
502 alp = math_utils::detail::angle2Alpha<value_t>(alp);
504 math_utils::detail::sincos(alp, sn, cs);
507 if (gpu::CAMath::Abs(sn) < 2.f * kSafe) {
509 alp += alp < constants::math::PIHalf ? 2.f * kSafe : -2.f * kSafe;
511 alp += alp > -constants::math::PIHalf ? -2.f * kSafe : 2.f * kSafe;
513 math_utils::detail::sincos(alp, sn, cs);
514 }
else if (gpu::CAMath::Abs(cs) < 2.f * kSafe) {
516 alp += alp > constants::math::PIHalf ? 2.f * kSafe : -2.f * kSafe;
518 alp += alp > -constants::math::PIHalf ? 2.f * kSafe : -2.f * kSafe;
520 math_utils::detail::sincos(alp, sn, cs);
523 dim3_t ver{xyz[0], xyz[1], xyz[2]};
524 dim3_t mom{pxpypz[0], pxpypz[1], pxpypz[2]};
527 math_utils::detail::rotateZ<value_t>(ver, -alp);
528 math_utils::detail::rotateZ<value_t>(mom, -alp);
530 value_t pt = gpu::CAMath::Sqrt(mom[0] * mom[0] + mom[1] * mom[1]);
536 this->setSnp(mom[1] * ptI);
537 this->setTgl(mom[2] * ptI);
538 this->setAbsCharge(gpu::CAMath::Abs(
charge));
542 if (gpu::CAMath::Abs(1.f - this->getSnp()) < kSafe) {
543 this->setSnp(1.f - kSafe);
544 }
else if (gpu::CAMath::Abs(-1.f - this->getSnp()) < kSafe) {
545 this->setSnp(-1.f + kSafe);
550 value_t cv34 = gpu::CAMath::Sqrt(cv[3] * cv[3] + cv[4] * cv[4]);
553 value_t sgcheck =
r * sn + this->getSnp() * cs;
554 if (gpu::CAMath::Abs(sgcheck) > 1 - kSafe) {
556 sgcheck = sgcheck < 0 ? -1.f : 1.f;
557 }
else if (gpu::CAMath::Abs(sgcheck) < kSafe) {
558 sgcheck = cs < 0 ? -1.0f : 1.0f;
562 mC[
kSigY2] = cv[0] + cv[2];
563 mC[
kSigZY] = (-cv[3] * sn) < 0 ? -cv34 : cv34;
567 value_t tgl2 = this->getTgl() * this->getTgl();
570 mC[
kSigSnpZ] = -sgcheck * cv[8] *
r * ptI;
571 mC[
kSigSnp2] = gpu::CAMath::Abs(cv[9] *
r *
r * ptI2);
572 mC[
kSigTglY] = (cv[10] * this->getTgl() - sgcheck * cv[15]) * ptI /
r;
573 mC[
kSigTglZ] = (cv[17] - sgcheck * cv[12] * this->getTgl()) * ptI;
574 mC[
kSigTglSnp] = (-sgcheck * cv[18] + cv[13] * this->getTgl()) *
r * ptI2;
575 mC[
kSigTgl2] = gpu::CAMath::Abs(cv[20] - 2 * sgcheck * cv[19] * mC[4] + cv[14] * tgl2) * ptI2;
579 mC[
kSigQ2PtTgl] = (-sgcheck * cv[19] + cv[14] * this->getTgl()) *
r * ptI2 * ptI;
580 mC[
kSigQ2Pt2] = gpu::CAMath::Abs(cv[14] * ptI2 * ptI2);
581 }
else if (special == 2) {
582 mC[
kSigSnpY] = -cv[10] * ptI * cs / sn;
584 mC[
kSigSnp2] = gpu::CAMath::Abs(cv[14] * cs * cs * ptI2);
585 mC[
kSigTglY] = (sgcheck * cv[6] * this->getTgl() - cv[15]) * ptI / sn;
586 mC[
kSigTglZ] = (cv[17] - sgcheck * cv[8] * this->getTgl()) * ptI;
587 mC[
kSigTglSnp] = (cv[19] - sgcheck * cv[13] * this->getTgl()) * cs * ptI2;
588 mC[
kSigTgl2] = gpu::CAMath::Abs(cv[20] - 2 * sgcheck * cv[18] * this->getTgl() + cv[9] * tgl2) * ptI2;
592 mC[
kSigQ2PtTgl] = (-sgcheck * cv[18] + cv[9] * this->getTgl()) * ptI2 * ptI *
charge;
593 mC[
kSigQ2Pt2] = gpu::CAMath::Abs(cv[9] * ptI2 * ptI2);
596 double m23 = -pt * (sn + this->getSnp() * cs /
r), m43 = -pt * pt * (
r * cs - this->getSnp() * sn);
597 double m24 = pt * (cs - this->getSnp() * sn /
r), m44 = -pt * pt * (
r * sn + this->getSnp() * cs);
598 double m35 = pt, m45 = -pt * pt * this->getTgl();
606 double a1 = cv[13] - cv[9] * (m23 * m44 + m43 * m24) / m23 / m43;
607 double a2 = m23 * m24 - m23 * (m23 * m44 + m43 * m24) / m43;
608 double a3 = m43 * m44 - m43 * (m23 * m44 + m43 * m24) / m23;
609 double a4 = cv[14] + 2. * cv[9];
610 double a5 = m24 * m24 - 2. * m24 * m44 * m23 / m43;
611 double a6 = m44 * m44 - 2. * m24 * m44 * m43 / m23;
613 mC[
kSigSnpY] = (cv[10] * m43 - cv[6] * m44) / (m24 * m43 - m23 * m44) / m00;
616 mC[
kSigSnpZ] = (cv[12] * m43 - cv[8] * m44) / (m24 * m43 - m23 * m44);
619 mC[
kSigSnp2] = gpu::CAMath::Abs((a4 * a3 - a6 * a1) / (a5 * a3 - a6 * a2));
623 double b2 = m23 * m35;
624 double b3 = m43 * m35;
626 double b5 = m24 * m35;
627 double b6 = m44 * m35;
628 mC[
kSigTglSnp] = (b4 - b6 * b1 / b3) / (b5 - b6 * b2 / b3);
636template <
typename value_T>
647 if (gpu::CAMath::Abs(dx) < constants::math::Almost0) {
651 if (gpu::CAMath::Abs(dx) > 1e5 || gpu::CAMath::Abs(this->
getY()) > 1e5 || gpu::CAMath::Abs(this->getZ()) > 1e5) {
652 LOG(warning) <<
"Anomalous track, target X:" << xk;
656 value_t crv = (gpu::CAMath::Abs(
b[2]) < constants::math::Almost0) ? 0.f :
this->getCurvature(
b[2]);
657 if (gpu::CAMath::Abs(crv) < constants::math::Almost0) {
658 return propagateTo(xk, 0.);
662 if ((gpu::CAMath::Abs(
f1) > constants::math::Almost1) || (gpu::CAMath::Abs(
f2) > constants::math::Almost1)) {
665 value_t r1 = gpu::CAMath::Sqrt((1.f -
f1) * (1.f +
f1));
666 if (gpu::CAMath::Abs(r1) < constants::math::Almost0) {
669 value_t r2 = gpu::CAMath::Sqrt((1.f -
f2) * (1.f +
f2));
670 if (gpu::CAMath::Abs(r2) < constants::math::Almost0) {
673 double r1pr2Inv = 1. / (r1 + r2), r2inv = 1. / r2, r1inv = 1. / r1;
674 double dy2dx = (
f1 +
f2) * r1pr2Inv, dx2r1pr2 = dx * r1pr2Inv;
675 value_t step = (gpu::CAMath::Abs(x2r) < 0.05f) ? dx * gpu::CAMath::Abs(r2 +
f2 * dy2dx)
676 : 2.f * gpu::CAMath::ASin(0.5f * dx * gpu::CAMath::Sqrt(1.f + dy2dx * dy2dx) * crv) / crv;
677 step *= gpu::CAMath::Sqrt(1.f + this->getTgl() * this->getTgl());
680 std::array<value_t, 9> vecLab{0.f};
681 if (!this->getPosDirGlo(vecLab)) {
692 value_t kb =
b[2] * constants::math::B2C;
693 double hh = dx2r1pr2 * r2inv * (1. + r1 * r2 +
f1 *
f2), jj = dx * (dy2dx -
f2 * r2inv);
694 double f02 = hh * r1inv;
695 double f04 = hh * dx2r1pr2 * kb;
696 double f24 = dx * kb;
697 double f12 = this->getTgl() * (f02 *
f2 + jj);
698 double f13 = dx * (r2 +
f2 * dy2dx);
699 double f14 = this->getTgl() * (f04 *
f2 + jj * f24);
702 double b00 = f02 * c20 + f04 * c40, b01 = f12 * c20 + f14 * c40 + f13 * c30;
703 double b02 = f24 * c40;
704 double b10 = f02 * c21 + f04 * c41, b11 = f12 * c21 + f14 * c41 + f13 * c31;
705 double b12 = f24 * c41;
706 double b20 = f02 * c22 + f04 * c42, b21 = f12 * c22 + f14 * c42 + f13 * c32;
707 double b22 = f24 * c42;
708 double b40 = f02 * c42 + f04 * c44, b41 = f12 * c42 + f14 * c44 + f13 * c43;
709 double b42 = f24 * c44;
710 double b30 = f02 * c32 + f04 * c43, b31 = f12 * c32 + f14 * c43 + f13 * c33;
711 double b32 = f24 * c43;
714 double a00 = f02 * b20 + f04 * b40, a01 = f02 * b21 + f04 * b41, a02 = f02 * b22 + f04 * b42;
715 double a11 = f12 * b21 + f14 * b41 + f13 * b31, a12 = f12 * b22 + f14 * b42 + f13 * b32;
716 double a22 = f24 * b42;
719 c00 += b00 + b00 + a00;
720 c10 += b10 + b01 + a01;
721 c20 += b20 + b02 + a02;
724 c11 += b11 + b11 + a11;
725 c21 += b21 + b12 + a12;
728 c22 += b22 + b22 + a22;
736 value_t bt = gpu::CAMath::Sqrt(bxy2);
737 value_t cosphi = 1.f, sinphi = 0.f;
738 if (bt > constants::math::Almost0) {
742 value_t bb = gpu::CAMath::Sqrt(bxy2 +
b[2] *
b[2]);
743 value_t costet = 1., sintet = 0.;
744 if (
bb > constants::math::Almost0) {
748 std::array<value_t, 7>
vect{costet * cosphi * vecLab[0] + costet * sinphi * vecLab[1] - sintet * vecLab[2],
749 -sinphi * vecLab[0] + cosphi * vecLab[1],
750 sintet * cosphi * vecLab[0] + sintet * sinphi * vecLab[1] + costet * vecLab[2],
751 costet * cosphi * vecLab[3] + costet * sinphi * vecLab[4] - sintet * vecLab[5],
752 -sinphi * vecLab[3] + cosphi * vecLab[4],
753 sintet * cosphi * vecLab[3] + sintet * sinphi * vecLab[4] + costet * vecLab[5],
761 vecLab[0] = cosphi * costet *
vect[0] - sinphi *
vect[1] + cosphi * sintet *
vect[2];
762 vecLab[1] = sinphi * costet *
vect[0] + cosphi *
vect[1] + sinphi * sintet *
vect[2];
763 vecLab[2] = -sintet *
vect[0] + costet *
vect[2];
765 vecLab[3] = cosphi * costet *
vect[3] - sinphi *
vect[4] + cosphi * sintet *
vect[5];
766 vecLab[4] = sinphi * costet *
vect[3] + cosphi *
vect[4] + sinphi * sintet *
vect[5];
767 vecLab[5] = -sintet *
vect[3] + costet *
vect[5];
770 value_t sinalp = -vecLab[7], cosalp = vecLab[8];
771 value_t t = cosalp * vecLab[0] - sinalp * vecLab[1];
772 vecLab[1] = sinalp * vecLab[0] + cosalp * vecLab[1];
774 t = cosalp * vecLab[3] - sinalp * vecLab[4];
775 vecLab[4] = sinalp * vecLab[3] + cosalp * vecLab[4];
779 value_t x = vecLab[0],
y = vecLab[1],
z = vecLab[2];
780 if (gpu::CAMath::Abs(
x - xk) > constants::math::Almost0) {
781 if (gpu::CAMath::Abs(vecLab[3]) < constants::math::Almost0) {
784 auto dxFin = xk - vecLab[0];
786 y += vecLab[4] / vecLab[3] * dxFin;
787 z += vecLab[5] / vecLab[3] * dxFin;
791 t = 1.f / gpu::CAMath::Sqrt(vecLab[3] * vecLab[3] + vecLab[4] * vecLab[4]);
795 this->setSnp(vecLab[4] * t);
796 this->setTgl(vecLab[5] * t);
797 this->setQ2Pt(q * t / vecLab[6]);
803template <
typename value_T>
814 if (gpu::CAMath::Abs(dx) < constants::math::Almost0) {
818 if (gpu::CAMath::Abs(dx) > 1e5 || gpu::CAMath::Abs(this->
getY()) > 1e5 || gpu::CAMath::Abs(this->getZ()) > 1e5) {
819 LOG(warning) <<
"Anomalous track, target X:" << xk;
823 if (gpu::CAMath::Abs(dx) < constants::math::Almost0) {
829 value_t crv = (gpu::CAMath::Abs(
b[2]) < constants::math::Almost0) ? 0.f : linRef0.getCurvature(
b[2]);
830 if (gpu::CAMath::Abs(crv) < constants::math::Almost0) {
831 return propagateTo(xk, linRef0, 0.);
833 value_t kb =
b[2] * constants::math::B2C, x2r = crv * dx;
835 value_t snpRef0 = linRef0.getSnp(), snpRef1 = snpRef0 + x2r;
836 if ((gpu::CAMath::Abs(snpRef0) > constants::math::Almost1) || (gpu::CAMath::Abs(snpRef1) > constants::math::Almost1)) {
839 value_t cspRef0 = gpu::CAMath::Sqrt((1 - snpRef0) * (1 + snpRef0)), cspRef1 = gpu::CAMath::Sqrt((1 - snpRef1) * (1 + snpRef1));
840 if (gpu::CAMath::Abs(cspRef0) < constants::math::Almost0 || gpu::CAMath::Abs(cspRef1) < constants::math::Almost0) {
843 value_t cspRef0Inv =
value_t(1) / cspRef0, cspRef1Inv =
value_t(1) / cspRef1,
cc = cspRef0 + cspRef1, ccInv =
value_t(1) /
cc, dy2dx = (snpRef0 + snpRef1) * ccInv;
844 value_t step = (gpu::CAMath::Abs(crv * dx) < 0.05f) ? dx * (cspRef1 + snpRef1 * dy2dx) : 2. * gpu::CAMath::ASin(0.5 * dx * gpu::CAMath::Sqrt(1.f + dy2dx * dy2dx) * crv) / crv;
845 step *= gpu::CAMath::Sqrt(1.f + linRef0.getTgl() * linRef0.getTgl());
849 std::array<value_t, 9> vecLab{0.f};
850 if (!linRef0.getPosDirGlo(vecLab)) {
856 value_t bt = gpu::CAMath::Sqrt(bxy2);
857 value_t cosphi = 1.f, sinphi = 0.f;
858 if (bt > constants::math::Almost0) {
862 value_t bb = gpu::CAMath::Sqrt(bxy2 +
b[2] *
b[2]);
863 value_t costet = 1., sintet = 0.;
864 if (
bb > constants::math::Almost0) {
868 std::array<value_t, 7>
vect{costet * cosphi * vecLab[0] + costet * sinphi * vecLab[1] - sintet * vecLab[2],
869 -sinphi * vecLab[0] + cosphi * vecLab[1],
870 sintet * cosphi * vecLab[0] + sintet * sinphi * vecLab[1] + costet * vecLab[2],
871 costet * cosphi * vecLab[3] + costet * sinphi * vecLab[4] - sintet * vecLab[5],
872 -sinphi * vecLab[3] + cosphi * vecLab[4],
873 sintet * cosphi * vecLab[3] + sintet * sinphi * vecLab[4] + costet * vecLab[5],
881 vecLab[0] = cosphi * costet *
vect[0] - sinphi *
vect[1] + cosphi * sintet *
vect[2];
882 vecLab[1] = sinphi * costet *
vect[0] + cosphi *
vect[1] + sinphi * sintet *
vect[2];
883 vecLab[2] = -sintet *
vect[0] + costet *
vect[2];
885 vecLab[3] = cosphi * costet *
vect[3] - sinphi *
vect[4] + cosphi * sintet *
vect[5];
886 vecLab[4] = sinphi * costet *
vect[3] + cosphi *
vect[4] + sinphi * sintet *
vect[5];
887 vecLab[5] = -sintet *
vect[3] + costet *
vect[5];
890 value_t sinalp = -vecLab[7], cosalp = vecLab[8];
891 value_t t = cosalp * vecLab[0] - sinalp * vecLab[1];
892 vecLab[1] = sinalp * vecLab[0] + cosalp * vecLab[1];
894 t = cosalp * vecLab[3] - sinalp * vecLab[4];
895 vecLab[4] = sinalp * vecLab[3] + cosalp * vecLab[4];
899 value_t x = vecLab[0],
y = vecLab[1],
z = vecLab[2];
900 if (gpu::CAMath::Abs(
x - xk) > constants::math::Almost0) {
901 if (gpu::CAMath::Abs(vecLab[3]) < constants::math::Almost0) {
904 auto dxFin = xk - vecLab[0];
906 y += vecLab[4] / vecLab[3] * dxFin;
907 z += vecLab[5] / vecLab[3] * dxFin;
911 auto linRef1 = linRef0;
912 t = 1.f / gpu::CAMath::Sqrt(vecLab[3] * vecLab[3] + vecLab[4] * vecLab[4]);
916 linRef1.setSnp(snpRef1 = vecLab[4] * t);
917 linRef1.setTgl(vecLab[5] * t);
918 linRef1.setQ2Pt(q * t / vecLab[6]);
921 cspRef1 = gpu::CAMath::Sqrt((1 - snpRef1) * (1 + snpRef1));
922 cspRef1Inv =
value_t(1) / cspRef1;
923 cc = cspRef0 + cspRef1;
925 dy2dx = (snpRef0 + snpRef1) * ccInv;
926 double dxccInv = dx * ccInv, hh = dxccInv * cspRef1Inv * (1 + cspRef0 * cspRef1 + snpRef0 * snpRef1), jj = dx * (dy2dx - snpRef1 * cspRef1Inv);
927 double f02 = hh * cspRef0Inv;
928 double f04 = hh * dxccInv * kb;
929 double f24 = dx * kb;
930 double f12 = linRef0.getTgl() * (f02 * snpRef1 + jj);
931 double f13 = dx * (cspRef1 + snpRef1 * dy2dx);
932 double f14 = linRef0.getTgl() * (f04 * snpRef1 + jj * f24);
936 for (
int i = 0;
i < 5;
i++) {
937 diff[
i] = this->getParam(
i) - linRef0.getParam(
i);
940 if (gpu::CAMath::Abs(snpUpd) > constants::math::Almost1) {
944 this->setY(linRef1.getY() + diff[
kY] + f02 * diff[
kSnp] + f04 * diff[
kQ2Pt]);
945 this->setZ(linRef1.getZ() + diff[
kZ] + f13 * diff[
kTgl] + f14 * diff[
kQ2Pt]);
946 this->setSnp(snpUpd);
947 this->setTgl(linRef1.getTgl() + diff[
kTgl]);
948 this->setQ2Pt(linRef1.getQ2Pt() + diff[
kQ2Pt]);
959 double b00 = f02 * c20 + f04 * c40, b01 = f12 * c20 + f14 * c40 + f13 * c30;
960 double b02 = f24 * c40;
961 double b10 = f02 * c21 + f04 * c41, b11 = f12 * c21 + f14 * c41 + f13 * c31;
962 double b12 = f24 * c41;
963 double b20 = f02 * c22 + f04 * c42, b21 = f12 * c22 + f14 * c42 + f13 * c32;
964 double b22 = f24 * c42;
965 double b40 = f02 * c42 + f04 * c44, b41 = f12 * c42 + f14 * c44 + f13 * c43;
966 double b42 = f24 * c44;
967 double b30 = f02 * c32 + f04 * c43, b31 = f12 * c32 + f14 * c43 + f13 * c33;
968 double b32 = f24 * c43;
971 double a00 = f02 * b20 + f04 * b40, a01 = f02 * b21 + f04 * b41, a02 = f02 * b22 + f04 * b42;
972 double a11 = f12 * b21 + f14 * b41 + f13 * b31, a12 = f12 * b22 + f14 * b42 + f13 * b32;
973 double a22 = f24 * b42;
976 c00 += b00 + b00 + a00;
977 c10 += b10 + b01 + a01;
978 c20 += b20 + b02 + a02;
981 c11 += b11 + b11 + a11;
982 c21 += b21 + b12 + a12;
985 c22 += b22 + b22 + a22;
995template <
typename value_T>
999 constexpr float MaxCorr = 0.99;
1001 for (
int j =
i;
j--;) {
1002 auto sig2 = mC[DiagMap[
i]] * mC[DiagMap[
j]];
1003 auto& cov = mC[CovarMap[
i][
j]];
1004 if (cov * cov >= MaxCorr * sig2) {
1005 cov = gpu::CAMath::Sqrt(sig2) * (cov > 0. ? MaxCorr : -MaxCorr);
1012template <
typename value_T>
1067template <
typename value_T>
1072 if (s2 > constants::math::Almost0) {
1073 d0 = getSigmaY2() * s2;
1074 d1 = getSigmaZ2() * s2;
1075 d2 = getSigmaSnp2() * s2;
1076 d3 = getSigmaTgl2() * s2;
1077 d4 = getSigma1Pt2() * s2;
1105template <
typename value_T>
1109 auto sdd =
static_cast<double>(getSigmaY2()) +
static_cast<double>(cov[0]);
1110 auto sdz =
static_cast<double>(getSigmaZY()) +
static_cast<double>(cov[1]);
1111 auto szz =
static_cast<double>(getSigmaZ2()) +
static_cast<double>(cov[2]);
1112 auto det = sdd * szz - sdz * sdz;
1114 if (gpu::CAMath::Abs(det) < constants::math::Almost0) {
1115 return constants::math::VeryBig;
1120 auto chi2 = (d * (szz * d - sdz *
z) +
z * (sdd *
z - d * sdz)) / det;
1122#ifndef GPUCA_ALIGPUCODE
1123 LOGP(warning,
"Negative chi2={}, Cluster: {} {} {} Dy:{} Dz:{} | sdd:{} sdz:{} szz:{} det:{}", chi2, cov[0], cov[1], cov[2], d,
z, sdd, sdz, szz, det);
1124 LOGP(warning,
"Track: {}",
asString());
1131template <
typename value_T>
1135 auto sdd =
static_cast<double>(getSigmaY2()) +
static_cast<double>(cov[0]);
1136 auto sdz =
static_cast<double>(getSigmaZY()) +
static_cast<double>(cov[1]);
1137 auto szz =
static_cast<double>(getSigmaZ2()) +
static_cast<double>(cov[2]);
1138 auto det = sdd * szz - sdz * sdz;
1140 if (gpu::CAMath::Abs(det) < constants::math::Almost0) {
1141 return constants::math::VeryBig;
1147 return (d * (szz * d - sdz *
z) +
z * (sdd *
z - d * sdz)) / det;
1151template <
typename value_T>
1155 return getPredictedChi2(rhs, cov);
1159template <
typename value_T>
1163 cov(
kY,
kY) =
static_cast<double>(getSigmaY2()) +
static_cast<double>(
rhs.getSigmaY2());
1164 cov(
kZ,
kY) =
static_cast<double>(getSigmaZY()) +
static_cast<double>(
rhs.getSigmaZY());
1165 cov(
kZ,
kZ) =
static_cast<double>(getSigmaZ2()) +
static_cast<double>(
rhs.getSigmaZ2());
1166 cov(
kSnp,
kY) =
static_cast<double>(getSigmaSnpY()) +
static_cast<double>(
rhs.getSigmaSnpY());
1167 cov(
kSnp,
kZ) =
static_cast<double>(getSigmaSnpZ()) +
static_cast<double>(
rhs.getSigmaSnpZ());
1168 cov(
kSnp,
kSnp) =
static_cast<double>(getSigmaSnp2()) +
static_cast<double>(
rhs.getSigmaSnp2());
1169 cov(
kTgl,
kY) =
static_cast<double>(getSigmaTglY()) +
static_cast<double>(
rhs.getSigmaTglY());
1170 cov(
kTgl,
kZ) =
static_cast<double>(getSigmaTglZ()) +
static_cast<double>(
rhs.getSigmaTglZ());
1171 cov(
kTgl,
kSnp) =
static_cast<double>(getSigmaTglSnp()) +
static_cast<double>(
rhs.getSigmaTglSnp());
1172 cov(
kTgl,
kTgl) =
static_cast<double>(getSigmaTgl2()) +
static_cast<double>(
rhs.getSigmaTgl2());
1173 cov(
kQ2Pt,
kY) =
static_cast<double>(getSigma1PtY()) +
static_cast<double>(
rhs.getSigma1PtY());
1174 cov(
kQ2Pt,
kZ) =
static_cast<double>(getSigma1PtZ()) +
static_cast<double>(
rhs.getSigma1PtZ());
1175 cov(
kQ2Pt,
kSnp) =
static_cast<double>(getSigma1PtSnp()) +
static_cast<double>(
rhs.getSigma1PtSnp());
1176 cov(
kQ2Pt,
kTgl) =
static_cast<double>(getSigma1PtTgl()) +
static_cast<double>(
rhs.getSigma1PtTgl());
1177 cov(
kQ2Pt,
kQ2Pt) =
static_cast<double>(getSigma1Pt2()) +
static_cast<double>(
rhs.getSigma1Pt2());
1181template <
typename value_T>
1188 LOG(error) <<
"The reference Alpha of the tracks differ: " << this->getAlpha() <<
" : " <<
rhs.getAlpha();
1192 LOG(error) <<
"The reference X of the tracks differ: " << this->
getX() <<
" : " <<
rhs.getX();
1195 buildCombinedCovMatrix(rhs, covToSet);
1196 if (!covToSet.Invert()) {
1197 LOG(warning) <<
"Cov.matrix inversion failed: " << covToSet;
1200 double chi2diag = 0., chi2ndiag = 0., diff[
kNParams];
1202 diff[
i] = this->getParam(
i) -
rhs.getParam(
i);
1203 chi2diag += diff[
i] * diff[
i] * covToSet(
i,
i);
1206 for (
int j =
i;
j--;) {
1207 chi2ndiag += diff[
i] * diff[
j] * covToSet(
i,
j);
1210 return chi2diag + 2. * chi2ndiag;
1214template <
typename value_T>
1221 LOG(error) <<
"The reference Alpha of the tracks differ: " << this->getAlpha() <<
" : " <<
rhs.getAlpha();
1225 LOG(error) <<
"The reference X of the tracks differ: " << this->
getX() <<
" : " <<
rhs.getX();
1231 matC0(
kY,
kY) = getSigmaY2();
1232 matC0(
kZ,
kY) = getSigmaZY();
1233 matC0(
kZ,
kZ) = getSigmaZ2();
1234 matC0(
kSnp,
kY) = getSigmaSnpY();
1235 matC0(
kSnp,
kZ) = getSigmaSnpZ();
1236 matC0(
kSnp,
kSnp) = getSigmaSnp2();
1237 matC0(
kTgl,
kY) = getSigmaTglY();
1238 matC0(
kTgl,
kZ) = getSigmaTglZ();
1239 matC0(
kTgl,
kSnp) = getSigmaTglSnp();
1240 matC0(
kTgl,
kTgl) = getSigmaTgl2();
1241 matC0(
kQ2Pt,
kY) = getSigma1PtY();
1242 matC0(
kQ2Pt,
kZ) = getSigma1PtZ();
1246 MatrixD5 matK = matC0 * covInv;
1252 diff[
i] =
rhs.getParam(
i) - this->getParam(
i);
1256 this->updateParam(matK(
i,
j) * diff[
j],
i);
1282template <
typename value_T>
1287 buildCombinedCovMatrix(rhs, covI);
1288 if (!covI.Invert()) {
1289 LOG(warning) <<
"Cov.matrix inversion failed: " << covI;
1292 return update(rhs, covI);
1296template <
typename value_T>
1308 double r00 =
static_cast<double>(cov[0]) +
static_cast<double>(cm00);
1309 double r01 =
static_cast<double>(cov[1]) +
static_cast<double>(cm10);
1310 double r11 =
static_cast<double>(cov[2]) +
static_cast<double>(cm11);
1311 double det = r00 * r11 - r01 * r01;
1313 if (gpu::CAMath::Abs(det) < constants::math::Almost0) {
1316 double detI = 1. / det;
1322 double k00 = cm00 * r00 + cm10 * r01, k01 = cm00 * r01 + cm10 * r11;
1323 double k10 = cm10 * r00 + cm11 * r01, k11 = cm10 * r01 + cm11 * r11;
1324 double k20 = cm20 * r00 + cm21 * r01, k21 = cm20 * r01 + cm21 * r11;
1325 double k30 = cm30 * r00 + cm31 * r01, k31 = cm30 * r01 + cm31 * r11;
1326 double k40 = cm40 * r00 + cm41 * r01, k41 = cm40 * r01 + cm41 * r11;
1329 value_t dsnp = k20 * dy + k21 * dz;
1330 if (gpu::CAMath::Abs(this->getSnp() + dsnp) > constants::math::Almost1) {
1335 value_t(k40 * dy + k41 * dz)};
1336 this->updateParams(dP);
1338 double c01 = cm10, c02 = cm20, c03 = cm30, c04 = cm40;
1339 double c12 = cm21, c13 = cm31, c14 = cm41;
1341 cm00 -= k00 * cm00 + k01 * cm10;
1342 cm10 -= k00 * c01 + k01 * cm11;
1343 cm20 -= k00 * c02 + k01 * c12;
1344 cm30 -= k00 * c03 + k01 * c13;
1345 cm40 -= k00 * c04 + k01 * c14;
1347 cm11 -= k10 * c01 + k11 * cm11;
1348 cm21 -= k10 * c02 + k11 * c12;
1349 cm31 -= k10 * c03 + k11 * c13;
1350 cm41 -= k10 * c04 + k11 * c14;
1352 cm22 -= k20 * c02 + k21 * c12;
1353 cm32 -= k20 * c03 + k21 * c13;
1354 cm42 -= k20 * c04 + k21 * c14;
1356 cm33 -= k30 * c03 + k31 * c13;
1357 cm43 -= k30 * c04 + k31 * c14;
1359 cm44 -= k40 * c04 + k41 * c14;
1367template <
typename value_T>
1372 auto vtLoc = this->getVertexInTrackFrame(vtx);
1373 value_T chi2 = getPredictedChi2(vtLoc.yz, vtLoc.yzerr);
1374 return chi2 < maxChi2 && update(vtLoc.yz, vtLoc.yzerr) ? chi2 : -chi2;
1378template <
typename value_T>
1390 constexpr value_t kMSConst2 = 0.0136f * 0.0136f;
1391 constexpr value_t kMinP = 0.01f;
1393 value_t csp2 = (1.f - this->getSnp()) * (1.f + this->getSnp());
1394 value_t cst2I = (1.f + this->getTgl() * this->getTgl());
1400 auto m = this->getPID().getMass();
1401 int charge2 = this->getAbsCharge() * this->getAbsCharge();
1402 value_t p = this->getP(),
p0 =
p, p02 =
p *
p, e2 = p02 + this->getPID().getMass2(), massInv = 1. /
m,
bg =
p * massInv, dETot = 0.;
1403 value_t e = gpu::CAMath::Sqrt(e2), e0 = e;
1404 if (
m > 0 && xrho != 0.f) {
1406#ifdef _BB_NONCONST_CORR_
1420#ifdef _BB_NONCONST_CORR_
1421 dedxDer = this->getBetheBlochSolidDerivativeApprox(dedx1,
bg);
1428#ifdef _BB_NONCONST_CORR_
1429 if (dedxDer != 0.) {
1433 auto corrC = (gpu::CAMath::Exp(dedxDer) - 1.) / dedxDer;
1439 p = gpu::CAMath::Sqrt(e * e - this->getPID().getMass2());
1445 dedx = this->getdEdxBBOpt(
bg);
1446#ifdef _BB_NONCONST_CORR_
1447 dedxDer = this->getBetheBlochSolidDerivativeApprox(
dedx,
bg);
1451#ifdef _BB_NONCONST_CORR_
1471 value_t cC22(0.f), cC33(0.f), cC43(0.f), cC44(0.f);
1473 value_t beta2 = p02 / e2, theta2 = kMSConst2 / (
beta2 * p02) * gpu::CAMath::Abs(x2x0);
1474 value_t fp34 = this->getTgl();
1477 fp34 *= this->getCharge2Pt();
1479 if (theta2 > constants::math::PI * constants::math::PI) {
1482 value_t t2c2I = theta2 * cst2I;
1483 cC22 = t2c2I * csp2;
1484 cC33 = t2c2I * cst2I;
1485 cC43 = t2c2I * fp34;
1486 cC44 = theta2 * fp34 * fp34;
1495 constexpr value_t knst = 0.0007f;
1496 value_t sigmadE = knst * gpu::CAMath::Sqrt(gpu::CAMath::Abs(dETot)) * e0 / p02 * this->getCharge2Pt();
1497 cC44 += sigmadE * sigmadE;
1504 this->setQ2Pt(this->getQ2Pt() * p0 / p);
1512template <
typename value_T>
1524 constexpr value_t kMSConst2 = 0.0136f * 0.0136f;
1525 constexpr value_t kMinP = 0.01f;
1527 value_t csp2 = (1.f - linRef.getSnp()) * (1.f + linRef.getSnp());
1528 value_t cst2I = (1.f + linRef.getTgl() * linRef.getTgl());
1534 auto pid = linRef.getPID();
1535 auto m =
pid.getMass();
1536 int charge2 = linRef.getAbsCharge() * linRef.getAbsCharge();
1537 value_t p = linRef.getP(),
p0 =
p, p02 =
p *
p, e2 = p02 +
pid.getMass2(), massInv = 1. /
m,
bg =
p * massInv, dETot = 0.;
1538 value_t e = gpu::CAMath::Sqrt(e2), e0 = e;
1539 if (
m > 0 && xrho != 0.f) {
1541#ifdef _BB_NONCONST_CORR_
1555#ifdef _BB_NONCONST_CORR_
1556 dedxDer = this->getBetheBlochSolidDerivativeApprox(dedx1,
bg);
1563#ifdef _BB_NONCONST_CORR_
1564 if (dedxDer != 0.) {
1568 auto corrC = (gpu::CAMath::Exp(dedxDer) - 1.) / dedxDer;
1574 p = gpu::CAMath::Sqrt(e * e -
pid.getMass2());
1580 dedx = this->getdEdxBBOpt(
bg);
1581#ifdef _BB_NONCONST_CORR_
1582 dedxDer = this->getBetheBlochSolidDerivativeApprox(
dedx,
bg);
1586#ifdef _BB_NONCONST_CORR_
1606 value_t cC22(0.f), cC33(0.f), cC43(0.f), cC44(0.f);
1608 value_t beta2 = p02 / e2, theta2 = kMSConst2 / (
beta2 * p02) * gpu::CAMath::Abs(x2x0);
1609 value_t fp34 = linRef.getTgl();
1612 fp34 *= linRef.getCharge2Pt();
1614 if (theta2 > constants::math::PI * constants::math::PI) {
1617 value_t t2c2I = theta2 * cst2I;
1618 cC22 = t2c2I * csp2;
1619 cC33 = t2c2I * cst2I;
1620 cC43 = t2c2I * fp34;
1621 cC44 = theta2 * fp34 * fp34;
1630 constexpr value_t knst = 0.0007f;
1631 value_t sigmadE = knst * gpu::CAMath::Sqrt(gpu::CAMath::Abs(dETot)) * e0 / p02 * linRef.getCharge2Pt();
1632 cC44 += sigmadE * sigmadE;
1639 auto pscale =
p0 /
p;
1640 linRef.setQ2Pt(linRef.getQ2Pt() * pscale);
1641 this->setQ2Pt(this->getQ2Pt() * pscale);
1649template <
typename value_T>
1664 if (gpu::CAMath::Abs(this->getQ2Pt()) <= constants::math::Almost0 || gpu::CAMath::Abs(this->getSnp()) > constants::math::Almost1) {
1665 for (
int i = 0;
i < 21;
i++) {
1671 auto pt = this->getPt();
1673 o2::math_utils::detail::sincos(this->getAlpha(), sn, cs);
1674 auto r = gpu::CAMath::Sqrt((1. - this->getSnp()) * (1. + this->getSnp()));
1675 auto m00 = -sn, m10 = cs;
1676 auto m23 = -pt * (sn + this->getSnp() * cs /
r), m43 = -pt * pt * (
r * cs - this->getSnp() * sn);
1677 auto m24 = pt * (cs - this->getSnp() * sn /
r), m44 = -pt * pt * (
r * sn + this->getSnp() * cs);
1678 auto m35 = pt, m45 = -pt * pt * this->getTgl();
1680 if (this->getSign() < 0) {
1686 cv[0] = mC[0] * m00 * m00;
1687 cv[1] = mC[0] * m00 * m10;
1688 cv[2] = mC[0] * m10 * m10;
1689 cv[3] = mC[1] * m00;
1690 cv[4] = mC[1] * m10;
1692 cv[6] = m00 * (mC[3] * m23 + mC[10] * m43);
1693 cv[7] = m10 * (mC[3] * m23 + mC[10] * m43);
1694 cv[8] = mC[4] * m23 + mC[11] * m43;
1695 cv[9] = m23 * (mC[5] * m23 + mC[12] * m43) + m43 * (mC[12] * m23 + mC[14] * m43);
1696 cv[10] = m00 * (mC[3] * m24 + mC[10] * m44);
1697 cv[11] = m10 * (mC[3] * m24 + mC[10] * m44);
1698 cv[12] = mC[4] * m24 + mC[11] * m44;
1699 cv[13] = m23 * (mC[5] * m24 + mC[12] * m44) + m43 * (mC[12] * m24 + mC[14] * m44);
1700 cv[14] = m24 * (mC[5] * m24 + mC[12] * m44) + m44 * (mC[12] * m24 + mC[14] * m44);
1701 cv[15] = m00 * (mC[6] * m35 + mC[10] * m45);
1702 cv[16] = m10 * (mC[6] * m35 + mC[10] * m45);
1703 cv[17] = mC[7] * m35 + mC[11] * m45;
1704 cv[18] = m23 * (mC[8] * m35 + mC[12] * m45) + m43 * (mC[13] * m35 + mC[14] * m45);
1705 cv[19] = m24 * (mC[8] * m35 + mC[12] * m45) + m44 * (mC[13] * m35 + mC[14] * m45);
1706 cv[20] = m35 * (mC[9] * m35 + mC[13] * m45) + m45 * (mC[13] * m35 + mC[14] * m45);
1711#ifndef GPUCA_ALIGPUCODE
1713template <
typename value_T>
1717 fmt::format(
" Cov: [{:+.3e}] [{:+.3e} {:+.3e}] [{:+.3e} {:+.3e} {:+.3e}] [{:+.3e} {:+.3e} {:+.3e} {:+.3e}] [{:+.3e} {:+.3e} {:+.3e} {:+.3e} {:+.3e}]",
1723template <
typename value_T>
1727 fmt::format(
" Cov: [{:x}] [{:x} {:x}] [{:x} {:x} {:x}] [{:x} {:x} {:x} {:x}] [{:x} {:x} {:x} {:x} {:x}]",
1728 reinterpret_cast<const unsigned int&
>(mC[
kSigY2]),
reinterpret_cast<const unsigned int&
>(mC[
kSigZY]),
reinterpret_cast<const unsigned int&
>(mC[
kSigZ2]),
1729 reinterpret_cast<const unsigned int&
>(mC[
kSigSnpY]),
reinterpret_cast<const unsigned int&
>(mC[
kSigSnpZ]),
reinterpret_cast<const unsigned int&
>(mC[
kSigSnp2]),
1730 reinterpret_cast<const unsigned int&
>(mC[
kSigTglY]),
reinterpret_cast<const unsigned int&
>(mC[
kSigTglZ]),
reinterpret_cast<const unsigned int&
>(mC[
kSigTglSnp]),
1731 reinterpret_cast<const unsigned int&
>(mC[
kSigTgl2]),
reinterpret_cast<const unsigned int&
>(mC[
kSigQ2PtY]),
reinterpret_cast<const unsigned int&
>(mC[
kSigQ2PtZ]),
1732 reinterpret_cast<const unsigned int&
>(mC[
kSigQ2PtSnp]),
reinterpret_cast<const unsigned int&
>(mC[
kSigQ2PtTgl]),
reinterpret_cast<const unsigned int&
>(mC[
kSigQ2Pt2]));
1737template <
typename value_T>
1741#ifndef GPUCA_ALIGPUCODE
1742 printf(
"%s\n",
asString().c_str());
1743#elif !defined(GPUCA_GPUCODE_DEVICE) || (!defined(__OPENCL__) && defined(GPUCA_GPU_DEBUG_PRINT))
1746 " Cov: [%+.3e] [%+.3e %+.3e] [%+.3e %+.3e %+.3e] [%+.3e %+.3e %+.3e %+.3e] [%+.3e %+.3e %+.3e %+.3e %+.3e]\n",
1754template <
typename value_T>
1758#ifndef GPUCA_ALIGPUCODE
1759 printf(
"%s\n", asStringHexadecimal().c_str());
1760#elif !defined(GPUCA_GPUCODE_DEVICE) || (!defined(__OPENCL__) && defined(GPUCA_GPU_DEBUG_PRINT))
1763 " Cov: [%x] [%x %x] [%x %x %x] [%x %x %x %x] [%x %x %x %x %x]\n",
1764 gpu::CAMath::Float2UIntReint(mC[
kSigY2]),
1765 gpu::CAMath::Float2UIntReint(mC[
kSigZY]), gpu::CAMath::Float2UIntReint(mC[
kSigZ2]),
1766 gpu::CAMath::Float2UIntReint(mC[
kSigSnpY]), gpu::CAMath::Float2UIntReint(mC[
kSigSnpZ]), gpu::CAMath::Float2UIntReint(mC[
kSigSnp2]),
1767 gpu::CAMath::Float2UIntReint(mC[
kSigTglY]), gpu::CAMath::Float2UIntReint(mC[
kSigTglZ]), gpu::CAMath::Float2UIntReint(mC[
kSigTglSnp]), gpu::CAMath::Float2UIntReint(mC[
kSigTgl2]),
1772#ifndef GPUCA_ALIGPUCODE
1774template <
typename value_T>
1777 auto p = this->getXYZGlo();
1781 t.
setPhi(this->getPhi());
1789 value_T csa, sna, csP, snP, csp = gpu::CAMath::Sqrt((1. - this->getSnp()) * (1. + this->getSnp()));
1790 math_utils::detail::sincos(value_T(this->getAlpha()), sna, csa);
1791 math_utils::detail::sincos(value_T(t.
getPhi()), snP, csP);
1800 auto tgLI = 1 / this->getTgl();
1801 const value_T d1 = -sna;
1802 const value_T
d2 = -csP * tgLI;
1803 const value_T e1 = csa;
1804 const value_T e2 = -snP * tgLI;
1805 const value_T
f1 = 1 / csp;
1807 C(0, 0) = d1 * d1 * getSigmaY2() + 2 * d1 *
d2 * getSigmaZY() +
d2 *
d2 * getSigmaZ2();
1808 C(0, 1) = d1 * e1 * getSigmaY2() + (d1 * e2 +
d2 * e1) * getSigmaZY() +
d2 * e2 * getSigmaZ2();
1809 C(1, 1) = e1 * e1 * getSigmaY2() + 2 * e1 * e2 * getSigmaZY() + e2 * e2 * getSigmaZ2();
1811 C(0, 2) =
f1 * (d1 * getSigmaSnpY() +
d2 * getSigmaSnpZ());
1812 C(1, 2) =
f1 * (e1 * getSigmaSnpY() + e2 * getSigmaSnpZ());
1813 C(2, 2) =
f1 *
f1 * getSigmaSnp2();
1815 C(0, 3) = d1 * getSigmaTglY() +
d2 * getSigmaTglZ();
1816 C(1, 3) = e1 * getSigmaTglY() + e2 * getSigmaTglZ();
1817 C(2, 3) =
f1 * getSigmaTglSnp();
1818 C(3, 3) = getSigmaTgl2();
1820 C(0, 4) = d1 * getSigma1PtY() +
d2 * getSigma1PtZ();
1821 C(1, 4) = e1 * getSigma1PtY() + e2 * getSigma1PtZ();
1822 C(2, 4) =
f1 * getSigma1PtSnp();
1823 C(3, 4) = getSigma1PtTgl();
1824 C(4, 4) = getSigma1Pt2();
1832#if !defined(GPUCA_GPUCODE) || defined(GPUCA_GPUCODE_DEVICE)
1835#ifndef GPUCA_GPUCODE
std::string asString(TDataMember const &dm, char *pointer)
Base forward track model, params only, w/o covariance.
void setCovariances(const SMatrix55Sym &covariances)
void setTanl(Double_t tanl)
void setInvQPt(Double_t invqpt)
void setPhi(Double_t phi)
void setZ(Double_t z)
set Z coordinate (cm)
bool toFwdTrackParCov(TrackParCovFwd &t) const
std::string asString() const
std::string asStringHexadecimal()
std::string asStringHexadecimal()
std::string asString() const
GLfloat GLfloat GLfloat alpha
GLboolean GLboolean GLboolean b
typedef void(APIENTRYP PFNGLCULLFACEPROC)(GLenum mode)
GLdouble GLdouble GLdouble z
typename trackParam_t::params_t params_t
typename trackParam_t::dim3_t dim3_t
typename trackParam_t::value_t value_t
D const SVectorGPU< T, D > & rhs
double * getX(double *xyDxy, int N)
double * getY(double *xyDxy, int N)
constexpr float kCTgl2max
constexpr int kCovMatSize
constexpr float kCSnp2max
constexpr int kLabCovMatSize
constexpr float DefaultDCACov
value_T std::array< value_T, 7 > & vect
GPUd() value_T BetheBlochSolid(value_T bg
constexpr float kC1Pt2max
constexpr float DefaultDCA
constexpr int MaxELossIter
constexpr float ELoss2EKinThreshInv
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
Defining DataPointCompositeObject explicitly as copiable.
std::vector< o2::mch::ChannelCode > cc
LOG(info)<< "Compressed in "<< sw.CpuTime()<< " s"