14 #if (defined(DUMPHITWINDOW) || defined(DEBUG_BACKWARD_FIT)) && defined(MKFIT_STANDALONE) 18 #ifndef MKFIT_STANDALONE 26 #ifndef MKFIT_STANDALONE 29 return std::isfinite(
x);
39 const std::vector<bool> *ihm) {
65 const int iI = inputProp ?
iP :
iC;
67 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
73 const std::vector<Track> &
tracks,
const std::vector<int> &idxs,
int beg,
int end,
bool inputProp,
int mp_offset) {
79 const int iI = inputProp ?
iP :
iC;
81 for (
int i = beg, imp = mp_offset;
i < end; ++
i, ++imp) {
96 const int iI = inputProp ?
iP :
iC;
98 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
104 m_SeedAlgo(imp, 0, 0) =
tracks[idxs[
i].first].seed_algo();
105 m_SeedLabel(imp, 0, 0) =
tracks[idxs[
i].first].seed_label();
115 const std::vector<UpdateIndices> &idxs,
124 const int iI = inputProp ?
iP :
iC;
126 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
132 m_SeedAlgo(imp, 0, 0) =
tracks[idxs[
i].seed_idx].seed_algo();
133 m_SeedLabel(imp, 0, 0) =
tracks[idxs[
i].seed_idx.seed_label();
146 const std::vector<std::pair<int, IdxChi2List>> &idxs,
155 const int iI = inputProp ?
iP :
iC;
157 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
163 m_SeedAlgo(imp, 0, 0) =
tracks[idxs[
i].first].seed_algo();
164 m_SeedLabel(imp, 0, 0) =
tracks[idxs[
i].first].seed_label();
176 const int iO = outputProp ?
iP :
iC;
178 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
184 std::vector<Track> &
tracks,
const std::vector<int> &idxs,
int beg,
int end,
bool outputProp)
const {
188 const int iO = outputProp ?
iP :
iC;
190 for (
int i = beg, imp = 0;
i < end; ++
i, ++imp) {
201 const float invpt,
const float theta,
float &min_dq,
float &max_dq,
float &min_dphi,
float &max_dphi) {
204 float max_invpt = invpt;
211 if ((ILC.
c_dq_sf) * this_dq > 0.f) {
212 min_dq = (ILC.
c_dq_sf) * this_dq;
213 max_dq = 2.0f * min_dq;
219 if ((ILC.
c_dp_sf) * this_dphi > min_dphi) {
220 min_dphi = (ILC.
c_dp_sf) * this_dphi;
221 max_dphi = 2.0f * min_dphi;
241 const float invpt =
m_Par[ipar].
At(itrk, 3, 0);
244 float max_invpt = invpt;
250 if ((ILC.
c_c2_sf) * this_c2 > minChi2Cut)
270 const float nSigmaR = 3;
272 dprintf(
"LayerOfHits::SelectHitIndices %s layer=%d N_proc=%d\n",
273 L.is_barrel() ?
"barrel" :
"endcap",
277 float dqv[
NN], dphiv[
NN], qv[
NN], phiv[
NN];
278 bidx_t qb1v[
NN], qb2v[
NN], qbv[
NN], pb1v[
NN], pb2v[
NN];
280 const auto assignbins = [&](
int itrack,
289 dphi = std::clamp(
std::abs(dphi), min_dphi, max_dphi);
290 dq = std::clamp(dq, min_dq, max_dq);
294 dphiv[itrack] = dphi;
297 qbv[itrack] =
L.qBinChecked(
q);
298 qb1v[itrack] =
L.qBinChecked(
q - dq);
299 qb2v[itrack] =
L.qBinChecked(
q + dq) + 1;
300 pb1v[itrack] =
L.phiBinChecked(phi - dphi);
301 pb2v[itrack] =
L.phiMaskApply(
L.phiBin(phi + dphi) + 1);
304 const auto calcdphi2 = [&](
int itrack,
float dphidx,
float dphidy) {
309 const auto calcdphi = [&](
float dphi2,
float min_dphi) {
316 for (
int itrack = 0; itrack <
NN; ++itrack) {
319 float min_dq = ILC.
min_dq();
320 float max_dq = ILC.
max_dq();
324 const float invpt =
m_Par[iI].
At(itrack, 3, 0);
330 const float r2 =
x *
x + y * y;
331 const float dphidx = -y /
r2, dphidy =
x /
r2;
332 const float dphi2 = calcdphi2(itrack, dphidx, dphidy);
337 const float phi =
getPhi(
x, y);
338 float dphi = calcdphi(dphi2, min_dphi);
342 const float edgeCorr =
std::abs(0.5
f * (
L.layer_info()->rout() -
L.layer_info()->rin()) /
347 assignbins(itrack, z,
dz, phi, dphi, min_dq, max_dq, min_dphi, max_dphi);
352 const float layerD =
std::abs(
L.layer_info()->zmax() -
L.layer_info()->zmin()) * 0.5
f *
356 for (
int itrack = 0; itrack <
NN; ++itrack) {
359 float min_dq = ILC.
min_dq();
360 float max_dq = ILC.
max_dq();
364 const float invpt =
m_Par[iI].
At(itrack, 3, 0);
370 const float r2 =
x *
x + y * y;
371 const float r2Inv = 1.f /
r2;
372 const float dphidx = -y * r2Inv, dphidy =
x * r2Inv;
373 const float phi =
getPhi(
x, y);
375 calcdphi2(itrack, dphidx, dphidy)
383 float dphi = calcdphi(dphi2, min_dphi);
387 y * y *
m_Err[iI].constAt(itrack, 1, 1) +
388 2 *
x * y *
m_Err[iI].constAt(itrack, 0, 1)) /
390 const float edgeCorr =
std::abs(0.5
f * (
L.layer_info()->zmax() -
L.layer_info()->zmin()) *
394 assignbins(itrack, r, dr, phi, dphi, min_dq, max_dq, min_dphi, max_dphi);
400 for (
int itrack = 0; itrack < N_proc; ++itrack) {
406 const bidx_t qb = qbv[itrack];
407 const bidx_t qb1 = qb1v[itrack];
408 const bidx_t qb2 = qb2v[itrack];
409 const bidx_t pb1 = pb1v[itrack];
410 const bidx_t pb2 = pb2v[itrack];
413 const float q = qv[itrack];
414 const float phi = phiv[itrack];
415 const float dphi = dphiv[itrack];
416 const float dq = dqv[itrack];
418 dprintf(
" %2d/%2d: %6.3f %6.3f %6.6f %7.5f %3u %3u %4u %4u\n",
419 L.layer_id(), itrack,
q, phi, dq, dphi,
427 #if defined(DUMPHITWINDOW) && defined(MKFIT_STANDALONE) 428 int thisseedmcid = -999999;
430 int seedlabel = m_SeedLabel(itrack, 0, 0);
431 TrackVec &seedtracks = m_event->seedTracks_;
432 int thisidx = -999999;
433 for (
int i = 0;
i <
int(seedtracks.size()); ++
i) {
434 auto &thisseed = seedtracks[
i];
435 if (thisseed.label() == seedlabel) {
440 if (thisidx > -999999) {
441 auto &seedtrack = m_event->seedTracks_[thisidx];
442 std::vector<int> thismcHitIDs;
443 seedtrack.mcHitIDsVec(m_event->layerHits_, m_event->simHitsInfo_, thismcHitIDs);
444 if (std::adjacent_find(thismcHitIDs.begin(), thismcHitIDs.end(), std::not_equal_to<>()) ==
445 thismcHitIDs.end()) {
446 thisseedmcid = thismcHitIDs.at(0);
452 for (bidx_t qi = qb1; qi != qb2; ++qi) {
453 for (bidx_t
pi = pb1;
pi != pb2;
pi =
L.phiMaskApply(
pi + 1)) {
455 if (qi == qb &&
L.isBinDead(
pi, qi) ==
true) {
456 dprint(
"dead module for track in layer=" <<
L.layer_id() <<
" qb=" << qi <<
" pi=" <<
pi <<
" q=" <<
q 469 auto pbi =
L.phiQBinContent(
pi, qi);
470 for (bcnt_t
hi = pbi.begin();
hi < pbi.end(); ++
hi) {
473 unsigned int hi_orig =
L.getOriginalHitIndex(
hi);
477 "Yay, denying masked hit on layer %u, hi %u, orig idx %u\n",
L.layer_info()->layer_id(),
hi, hi_orig);
488 #if defined(DUMPHITWINDOW) && defined(MKFIT_STANDALONE) 490 const MCHitInfo &mchinfo = m_event->simHitsInfo_[
L.refHit(
hi).mcHitID()];
492 int st_isfindable = 0;
493 int st_label = -999999;
500 float st_eta = -999.;
501 float st_phi = -999.;
503 Track simtrack = m_event->simTracks_[mchid];
505 st_label = simtrack.
label();
507 st_pt = simtrack.
pT();
508 st_eta = simtrack.
momEta();
509 st_phi = simtrack.
momPhi();
511 st_charge = simtrack.
charge();
512 st_r = simtrack.
posR();
516 const Hit &thishit =
L.refHit(
hi);
534 float hx = thishit.
x();
535 float hy = thishit.
y();
536 float hz = thishit.
z();
537 float hr = std::hypot(hx, hy);
538 float hphi = std::atan2(hy, hx);
549 (hx * hx * thishit.
exx() + hy * hy * thishit.
eyy() + 2.0f * hx * hy *
m_msErr.
At(itrack, 0, 1)) /
556 float hchi2 = thisOutChi2[itrack];
559 float tx =
m_Par[iI].
At(itrack, 0, 0);
560 float ty =
m_Par[iI].
At(itrack, 1, 0);
561 float tz =
m_Par[iI].
At(itrack, 2, 0);
562 float tr = std::hypot(tx, ty);
563 float tphi = std::atan2(ty, tx);
564 float tchi2 =
m_Chi2(itrack, 0, 0);
577 (tx * tx *
tex *
tex + ty * ty * tey * tey + 2.0
f * tx * ty *
m_Err[iI].At(itrack, 0, 1)) /
582 (ty * ty *
tex *
tex + tx * tx * tey * tey - 2.0
f * tx * ty *
m_Err[iI].At(itrack, 0, 1)) /
583 (tr * tr * tr * tr));
586 float ht_dxy = std::hypot(hx - tx, hy - ty);
587 float ht_dz = hz - tz;
590 static bool first =
true;
595 "lyr_id/I:lyr_isbrl/I:hit_idx/I:" 596 "trk_cnt/I:trk_idx/I:trk_label/I:" 597 "trk_pt/F:trk_eta/F:trk_mphi/F:trk_chi2/F:" 599 "seed_idx/I:seed_label/I:seed_algo/I:seed_mcid/I:" 601 "st_isfindable/I:st_prodtype/I:st_label/I:" 602 "st_pt/F:st_eta/F:st_phi/F:" 603 "st_nhits/I:st_charge/I:st_r/F:st_z/F:" 604 "trk_q/F:hit_q/F:dq_trkhit/F:dq_cut/F:trk_phi/F:hit_phi/F:dphi_trkhit/F:dphi_cut/F:" 605 "t_x/F:t_y/F:t_r/F:t_phi/F:t_z/F:" 606 "t_ex/F:t_ey/F:t_er/F:t_ephi/F:t_ez/F:" 607 "h_x/F:h_y/F:h_r/F:h_phi/F:h_z/F:" 608 "h_ex/F:h_ey/F:h_er/F:h_ephi/F:h_ez/F:" 609 "ht_dxy/F:ht_dz/F:ht_dphi/F:" 618 printf(
"HITWINDOWSEL " 622 "%6.3f %6.3f %6.3f %6.3f " 629 "%6.3f %6.3f %6.3f %6.3f %6.3f %6.3f %6.3f %6.3f " 630 "%6.3f %6.3f %6.3f %6.3f %6.3f " 631 "%6.6f %6.6f %6.6f %6.6f %6.6f " 632 "%6.3f %6.3f %6.3f %6.3f %6.3f " 633 "%6.6f %6.6f %6.6f %6.6f %6.6f " 638 L.layer_id(),
L.is_barrel(),
L.getOriginalHitIndex(
hi),
640 1.0f /
m_Par[iI].
At(itrack, 3, 0),
getEta(
m_Par[iI].At(itrack, 5, 0)),
m_Par[iI].
At(itrack, 4, 0),
m_Chi2(itrack, 0, 0),
642 m_SeedIdx(itrack, 0, 0), m_SeedLabel(itrack, 0, 0), m_SeedAlgo(itrack, 0, 0), thisseedmcid,
644 st_isfindable, st_prodtype, st_label,
645 st_pt, st_eta, st_phi,
646 st_nhits, st_charge, st_r, st_z,
647 q,
L.hit_q(
hi), ddq, dq, phi,
L.hit_phi(
hi), ddphi, dphi,
648 tx, ty, tr, tphi, tz,
649 tex, tey, ter, tephi, tez,
650 hx, hy, hr, hphi, hz,
651 hex, hey, her, hephi, hez,
652 ht_dxy, ht_dz, ht_dphi,
664 dprintf(
" SHI %3u %4u %5u %6.3f %6.3f %6.4f %7.5f %s\n",
666 ddq, ddphi, (ddq < dq && ddphi < dphi) ?
"PASS" :
"FAIL");
681 assert(
false &&
"this code has not been used in a while -- see comments in code");
707 for (
int it = 0; it <
NN; ++it) {
718 for (
int hit_cnt = 0; hit_cnt <
maxSize; ++hit_cnt) {
724 for (
int itrack = 0; itrack < N_proc; ++itrack) {
748 for (
int itrack = 0; itrack < N_proc; ++itrack) {
754 bestHit[itrack] =
m_XHitArr.
At(itrack, hit_cnt, 0);
761 for (
int itrack = 0; itrack < N_proc; ++itrack) {
779 if (bestHit[itrack] >= 0) {
783 dprint(
"ADD BEST HIT FOR TRACK #" 784 << itrack << std::endl
785 <<
"prop x=" <<
m_Par[
iP].constAt(itrack, 0, 0) <<
" y=" <<
m_Par[
iP].constAt(itrack, 1, 0) << std::endl
786 <<
"copy in hit #" << bestHit[itrack] <<
" x=" <<
hit.position()[0] <<
" y=" <<
hit.position()[1]);
804 <<
" r=" << std::hypot(
m_Par[
iP](itrack, 0, 0),
m_Par[
iP](itrack, 1, 0)));
819 dprint(
"update parameters");
831 dprint(
"m_Par[iP](0,0,0)=" <<
m_Par[
iP](0, 0, 0) <<
" m_Par[iC](0,0,0)=" <<
m_Par[
iC](0, 0, 0));
842 const float hitHL =
sqrt(msErr.
constAt(itrack, 2, 2) * 3.f);
843 const float qErr =
sqrt(pErr.
constAt(itrack, 2, 2));
844 dprint(
"qCompat " << hitHL <<
" + " << 3.
f * qErr <<
" vs " <<
res);
849 const float hitT2 = msErr.
constAt(itrack, 0, 0) + msErr.
constAt(itrack, 1, 1);
850 const float hitT2inv = 1.f / hitT2;
851 const float proj[3] = {msErr.
constAt(itrack, 0, 0) * hitT2inv,
852 msErr.
constAt(itrack, 0, 1) * hitT2inv,
853 msErr.
constAt(itrack, 1, 1) * hitT2inv};
857 const float resProj =
859 dprint(
"qCompat " <<
sqrt(hitT2 * 3.
f) <<
" + " << 3.
f * qErr <<
" vs " << resProj);
870 int itrack,
bool isBarrel,
unsigned int pcm,
unsigned int pcmMin,
const MPlexLV &pPar,
const MPlexHS &msErr) {
877 const float hitT2 = msErr.
constAt(itrack, 0, 0) + msErr.
constAt(itrack, 1, 1);
878 const float hitT2inv = 1.f / hitT2;
879 const float proj[3] = {msErr.
constAt(itrack, 0, 0) * hitT2inv,
880 msErr.
constAt(itrack, 0, 1) * hitT2inv,
881 msErr.
constAt(itrack, 1, 1) * hitT2inv};
882 const bool detXY_OK =
884 const float cosP =
cos(pPar.
constAt(itrack, 4, 0));
885 const float sinP =
sin(pPar.
constAt(itrack, 4, 0));
889 2.
f * cosP * sinP *
proj[1]))
896 const float qCorr = pcm * qSF;
897 dprint(
"pcm " << pcm <<
" * " << qSF <<
" = " << qCorr <<
" vs " << pcmMin);
898 return qCorr > pcmMin;
906 std::vector<std::vector<TrackCand>> &tmp_candidates,
917 for (
int it = 0; it <
NN; ++it) {
927 int nHitsAdded[
NN]{};
928 bool isTooLargeCluster[
NN]{
false};
930 for (
int hit_cnt = 0; hit_cnt <
maxSize; ++hit_cnt) {
936 for (
int itrack = 0; itrack < N_proc; ++itrack) {
939 mhp.addInputAt(itrack,
hit);
940 charge_pcm[itrack] =
hit.chargePerCM();
966 bool oneCandPassCut =
false;
967 for (
int itrack = 0; itrack < N_proc; ++itrack) {
974 bool isCompatible =
true;
988 isTooLargeCluster[itrack] =
true;
989 isCompatible =
false;
994 oneCandPassCut =
true;
1001 if (oneCandPassCut) {
1014 dprint(
"update parameters" << std::endl
1015 <<
"propagated track parameters x=" <<
m_Par[
iP].constAt(0, 0, 0)
1016 <<
" y=" <<
m_Par[
iP].constAt(0, 1, 0) << std::endl
1024 for (
int itrack = 0; itrack < N_proc; ++itrack) {
1030 if (
chi2 < max_c2) {
1031 bool isCompatible =
true;
1045 isCompatible =
false;
1049 bool hitExists =
false;
1064 nHitsAdded[itrack]++;
1065 dprint(
"chi2 cut passed, creating new candidate");
1069 const int hit_idx =
m_XHitArr.
At(itrack, hit_cnt, 0);
1073 newcand.
setCharge(tmpChg(itrack, 0, 0));
1079 if (
chi2 < max_c2) {
1081 ccand[
m_CandIdx(itrack, 0, 0)].considerHitForOverlap(
1089 tmp_candidates[
m_SeedIdx(itrack, 0, 0) -
offset].emplace_back(newcand);
1100 for (
int itrack = 0; itrack < N_proc; ++itrack) {
1117 else if (
m_XWsrResult[itrack].m_in_gap ==
true && nHitsAdded[itrack] == 0) {
1121 else if (isTooLargeCluster[itrack] ==
true && nHitsAdded[itrack] == 0) {
1126 <<
" r=" << std::hypot(
m_Par[
iP](itrack, 0, 0),
m_Par[
iP](itrack, 1, 0)));
1135 tmp_candidates[
m_SeedIdx(itrack, 0, 0) -
offset].emplace_back(newcand);
1156 for (
int it = 0; it <
NN; ++it) {
1164 dprintf(
"FindCandidatesCloneEngine max hits to process=%d\n",
maxSize);
1166 int nHitsAdded[
NN]{};
1167 bool isTooLargeCluster[
NN]{
false};
1169 for (
int hit_cnt = 0; hit_cnt <
maxSize; ++hit_cnt) {
1175 for (
int itrack = 0; itrack < N_proc; ++itrack) {
1178 mhp.addInputAt(itrack,
hit);
1179 charge_pcm[itrack] =
hit.chargePerCM();
1199 #pragma omp simd // DOES NOT VECTORIZE AS IT IS NOW 1200 for (
int itrack = 0; itrack < N_proc; ++itrack) {
1209 dprint(
"chi2=" <<
chi2 <<
" for trkIdx=" << itrack <<
" hitIdx=" <<
m_XHitArr.
At(itrack, hit_cnt, 0));
1210 if (
chi2 < max_c2) {
1211 bool isCompatible =
true;
1226 isTooLargeCluster[itrack] =
true;
1227 isCompatible =
false;
1233 bool hitExists =
false;
1248 nHitsAdded[itrack]++;
1249 const int hit_idx =
m_XHitArr.
At(itrack, hit_cnt, 0);
1253 if (
chi2 < max_c2) {
1254 ccand[
m_CandIdx(itrack, 0, 0)].considerHitForOverlap(
1260 tmpList.
hitIdx = hit_idx;
1272 dprint(
" adding hit with hit_cnt=" << hit_cnt <<
" for trkIdx=" << tmpList.
trkIdx 1273 <<
" orig Seed=" <<
m_Label(itrack, 0, 0));
1282 for (
int itrack = 0; itrack < N_proc; ++itrack) {
1301 else if (
m_XWsrResult[itrack].m_in_gap ==
true && nHitsAdded[itrack] == 0) {
1305 else if (isTooLargeCluster[itrack] ==
true && nHitsAdded[itrack] == 0) {
1311 tmpList.
hitIdx = fake_hit_idx;
1323 dprint(
"adding invalid hit " << fake_hit_idx);
1351 const int iO = outputProp ?
iP :
iC;
1353 for (
int i = 0;
i < N_proc; ++
i) {
1361 dprint((outputProp ?
"propagated" :
"updated")
1362 <<
" track parameters x=" <<
cand.parameters()[0] <<
" y=" <<
cand.parameters()[1]
1363 <<
" z=" <<
cand.parameters()[2] <<
" pt=" << 1. /
cand.parameters()[3] <<
" posEta=" <<
cand.posEta());
1378 for (
int i = beg;
i < end; ++
i, ++itrack) {
1405 for (
int i = beg;
i < end; ++
i, ++itrack) {
1431 const int iO = outputProp ?
iP :
iC;
1434 for (
int i = beg;
i < end; ++
i, ++itrack) {
1452 const int iO = outputProp ?
iP :
iC;
1455 for (
int i = beg;
i < end; ++
i, ++itrack) {
1470 #if defined(DEBUG_BACKWARD_FIT) || defined(DEBUG_BACKWARD_FIT_BH) 1487 float tmp_err[6] = {666, 0, 666, 0, 0, 666};
1491 const int layer = lp_iter->m_layer;
1497 for (
int i = 0;
i < N_proc; ++
i) {
1555 for (
int n = 0;
n < N_proc; ++
n) {
1562 #ifdef DEBUG_BACKWARD_FIT_BH 1564 for (
int i = 0;
i < N_proc; ++
i) {
1573 "CHIHIT %3d %10g %10g %10g %10g %10g %11.5g %11.5g %11.5g %10g %10g %10g %10g %11.5g %11.5g %11.5g %10g " 1574 "%10g %10g %10g %10g %11.5g %11.5g\n",
1588 e2s(
m_Err[ti].At(
i, 0, 0)),
1589 e2s(
m_Err[ti].At(
i, 1, 1)),
1590 e2s(
m_Err[ti].At(
i, 2, 2)),
1625 float tmp_err[6] = {666, 0, 666, 0, 0, 666};
1629 const int layer = lp_iter.layer();
1635 #if defined(DEBUG_BACKWARD_FIT) 1636 const Hit *last_hit_ptr[
NN];
1642 for (
int i = 0;
i < N_proc; ++
i) {
1662 #ifdef DEBUG_BACKWARD_FIT 1663 last_hit_ptr[
i] = &
hit;
1671 #ifdef DEBUG_BACKWARD_FIT 1672 last_hit_ptr[
i] =
nullptr;
1683 if (done_count == N_proc)
1685 if (here_count == 0)
1717 for (
int n = 0;
n < N_proc; ++
n) {
1724 for (
int i = 0;
i < N_proc; ++
i) {
1725 #if defined(DEBUG_BACKWARD_FIT) 1726 if (chiDebug && last_hit_ptr[
i]) {
1729 float chi = tmp_chi2.
At(
i, 0, 0);
1730 float chi_prnt = std::isfinite(chi) ? chi : -9;
1732 #if defined(MKFIT_STANDALONE) 1736 "BKF_OVERLAP %d %d %d %d %d %d %d " 1737 "%f %f %f %f %d %d %d %d " 1742 "BKF_OVERLAP %d %d %d %d %d %d " 1743 "%f %f %f %f %d %d %d " 1759 #if defined(MKFIT_STANDALONE) 1762 e2s(
m_Err[ti].At(
i, 0, 0)),
1763 e2s(
m_Err[ti].At(
i, 1, 1)),
1764 e2s(
m_Err[ti].At(
i, 2, 2)),
void setOriginIndex(int oi)
void addHitIdx(int hitIdx, int hitLyr, float chi2)
unsigned int maxClusterSize
void copy_in(const Track &trk, const int mslot, const int tslot)
static constexpr int MPlexHitIdxMax
const SVector6 & parameters() const
const IterationLayerConfig * m_iteration_layer_config
void setDiagonal3x3(idx_t n, T d)
const HitOnTrack * m_HoTArr[NN]
void kalmanOperationEndcap(const int kfOp, const MPlexLS &psErr, const MPlexLV &psPar, const MPlexHS &msErr, const MPlexHV &msPar, MPlexLS &outErr, MPlexLV &outPar, MPlexQF &outChi2, const int N_proc)
void copy_out(Track &trk, const int mslot, const int tslot) const
void copyIn(idx_t n, const T *arr)
void outputTracksAndHitIdx(std::vector< Track > &tracks, int beg, int end, bool outputProp) const
HitOnTrack m_HoTArrs[NN][Config::nMaxTrkHits]
const Hit * hitArray() const
void inputTracksAndHitIdx(const std::vector< Track > &tracks, int beg, int end, bool inputProp)
void bkFitInputTracks(TrackVec &cands, int beg, int end)
const T & constAt(idx_t n, idx_t i, idx_t j) const
Sin< T >::type sin(const T &t)
PropagationFlags backward_fit_pflags
void addInput(const T &item)
ProdType prodType() const
T & At(idx_t n, idx_t i, idx_t j)
void selectHitIndices(const LayerOfHits &layer_of_hits, const int N_proc)
void bkFitPropTracksToPCA(const int N_proc)
SMatrixSym66 & errors_nc()
void inputTracksAndHits(const std::vector< CombCandidate > &tracks, const LayerOfHits &layer_of_hits, const std::vector< UpdateIndices > &idxs, int beg, int end, bool inputProp)
void add_hit(const int mslot, int index, int layer)
float getEta(float r, float z)
constexpr bool isFinite(T x)
const float * posArray() const
static unsigned int maxChargePerCM()
static constexpr int kHitStopIdx
const IterationParams * m_iteration_params
void kalmanOperation(const int kfOp, const MPlexLS &psErr, const MPlexLV &psPar, const MPlexHS &msErr, const MPlexHV &msPar, MPlexLS &outErr, MPlexLV &outPar, MPlexQF &outChi2, const int N_proc)
void findCandidates(const LayerOfHits &layer_of_hits, std::vector< std::vector< TrackCand >> &tmp_candidates, const int offset, const int N_proc, const FindingFoos &fnd_foos)
static constexpr int kHitInGapIdx
constexpr bool usePhiQArrays
const HoTNode * hotsData() const
PropagationFlags finding_inter_layer_pflags
bool isStripQCompatible(int itrack, bool isBarrel, const MPlexLS &pErr, const MPlexLV &pPar, const MPlexHS &msErr, const MPlexHV &msPar)
void add(const Matriplex &v)
const PropagationConfig * m_prop_config
void setup_bkfit(const PropagationConfig &pc)
iterator make_iterator(IterationType_e type) const
const T & constAt(idx_t n, idx_t i, idx_t j) const
int num_all_minus_one_hits(const int mslot) const
float getScoreStruct(const IdxChi2List &cand1)
float getScoreCand(const Track &cand1, bool penalizeTailMissHits=false, bool inFindCandidates=false)
unsigned int detIDinLayer() const
void(* m_compute_chi2_foo)(const MPlexLS &, const MPlexLV &, const MPlexQI &, const MPlexHS &, const MPlexHV &, MPlexQF &, MPlexLV &, const int, const PropagationFlags, const bool)
const float * errArray() const
constexpr Matriplex::idx_t NN
unsigned int bin_content_t
Cos< T >::type cos(const T &t)
CombCandidate * combCandidate() const
Tan< T >::type tan(const T &t)
Abs< T >::type abs(const T &t)
void propagateTracksToHitR(const MPlexHV &par, const int N_proc, const PropagationFlags pf, const MPlexQI *noMatEffPtr=nullptr)
MPlexQI m_NTailMinusOneHits
void copyOut(idx_t n, T *arr) const
const HitOnTrack * getHitsOnTrackArray() const
void setup(const PropagationConfig &pc, const IterationParams &ip, const IterationLayerConfig &ilc, const std::vector< bool > *ihm)
PropagationFlags pca_prop_pflags
bool finding_requires_propagation_to_hit_pos
constexpr float nSigmaPhi
TrackCand * m_TrkCand[NN]
std::vector< Track > TrackVec
auto const & tracks
cannot be loose
void pack(TMerr &err, TMpar &par)
void bkFitFitTracks(const EventOfHits &eventofhits, const SteeringParams &st_par, const int N_proc, bool chiDebug=false)
static const FindingFoos & get_finding_foos(bool is_barrel)
void updateWithLoadedHit(int N_proc, const FindingFoos &fnd_foos)
std::vector< LayerControl > m_layer_plan
bool passStripChargePCMfromTrack(int itrack, bool isBarrel, unsigned int pcm, unsigned int pcmMin, const MPlexLV &pPar, const MPlexHS &msErr)
float getPhi(float x, float y)
static constexpr int kHitMaxClusterIdx
void bkFitOutputTracks(TrackVec &cands, int beg, int end, bool outputProp)
void bkFitFitTracksBH(const EventOfHits &eventofhits, const SteeringParams &st_par, const int N_proc, bool chiDebug=false)
void copyIn(idx_t n, const T *arr)
HitOnTrack hot(int i) const
void copyOutParErr(std::vector< CombCandidate > &seed_cand_vec, int N_proc, bool outputProp) const
int num_inside_minus_one_hits(const int mslot) const
void findCandidatesCloneEngine(const LayerOfHits &layer_of_hits, CandCloner &cloner, const int offset, const int N_proc, const FindingFoos &fnd_foos)
void copyOut(idx_t n, T *arr) const
const std::vector< bool > * m_iteration_hit_mask
PropagationFlags finding_intra_layer_pflags
void add_cand(int idx, const IdxChi2List &cand_info)
float getHitSelDynamicChi2Cut(const int itrk, const int ipar)
static constexpr int kHitMissIdx
const HoTNode * m_HoTNodeArr[NN]
unsigned short bin_index_t
WSR_Result m_XWsrResult[NN]
void getHitSelDynamicWindows(const float invpt, const float theta, float &min_dq, float &max_dq, float &min_dphi, float &max_dphi)
Geom::Theta< T > theta() const
static constexpr int kHitEdgeIdx
void(* m_update_param_foo)(const MPlexLS &, const MPlexLV &, MPlexQI &, const MPlexHS &, const MPlexHV &, MPlexLS &, MPlexLV &, const int, const PropagationFlags, const bool)
T & At(idx_t n, idx_t i, idx_t j)
CombCandidate & combCandWithOriginalIndex(int idx)
static unsigned int minChargePerCM()
SVector6 & parameters_nc()
Power< A, B >::type pow(const A &a, const B &b)
void propagateTracksToHitZ(const MPlexHV &par, const int N_proc, const PropagationFlags pf, const MPlexQI *noMatEffPtr=nullptr)
void propagateTracksToPCAZ(const int N_proc, const PropagationFlags pf)
const Hit & refHit(int i) const
void addBestHit(const LayerOfHits &layer_of_hits, const int N_proc, const FindingFoos &fnd_foos)