55 auto id = trkTrd.getRefGlobalTrackId();
61 LOGF(
debug,
"Got track with %i tracklets and ID %i", trkTrd.getNtracklets(), (
int)
id);
65 qcStruct.
dEdxTotTPC = isTPCTRD ? mTracksTPC[
id].getdEdx().dEdxTotTPC : mTracksTPC[mTracksITSTPC[
id].getRefTPC()].getdEdx().dEdxTotTPC;
68 for (
int iLayer = 0; iLayer <
NLAYER; ++iLayer) {
69 int trkltId = trkTrd.getTrackletIndex(iLayer);
73 const auto& tracklet = mTrackletsRaw[trkltId];
74 qcStruct.
trklt64[iLayer] = tracklet;
75 qcStruct.
trkltCalib[iLayer] = mTrackletsCalib[trkltId];
76 int trkltDet = tracklet.getDetector();
80 LOGF(
debug,
"Track could not be rotated in tracklet coordinate system");
84 if (!propagator->PropagateToXBxByBz(trk, mTrackletsCalib[trkltId].getX(), mMaxSnp, mMaxStep, mMatCorr)) {
85 LOGF(
debug,
"Track propagation failed in layer %i (pt=%f, xTrk=%f, xToGo=%f)", iLayer, trk.getPt(), trk.getX(), mTrackletsCalib[trkltId].getX());
89 float tilt = tan(TMath::DegToRad() * pad->getTiltingAngle());
90 float tiltCorrUp = tilt * (mTrackletsCalib[trkltId].getZ() - trk.getZ());
91 float zPosCorrUp = mTrackletsCalib[trkltId].getZ() + mRecoParam.getZCorrCoeffNRC() * trk.getTgl();
92 float padLength = pad->getRowSize(tracklet.getPadRow());
93 if (!((trk.getSigmaZ2() < (padLength * padLength / 12.f)) && (std::fabs(mTrackletsCalib[trkltId].getZ() - trk.getZ()) < padLength))) {
96 std::array<float, 2> trkltPosUp{mTrackletsCalib[trkltId].getY() - tiltCorrUp, zPosCorrUp};
97 std::array<float, 3> trkltCovUp;
98 mRecoParam.recalcTrkltCov(tilt, trk.getSnp(), pad->getRowSize(tracklet.getPadRow()), trkltCovUp);
99 auto chi2trklt = trk.getPredictedChi2(trkltPosUp, trkltCovUp);
102 qcStruct.
trackletY[iLayer] = trkltPosUp[0];
103 qcStruct.
trackletZ[iLayer] = trkltPosUp[1];
110 auto tphi = trk.getSnp() / std::sqrt((1.f - trk.getSnp()) * (1.f + trk.getSnp()));
111 auto trackletLength = std::sqrt(1.f + tphi * tphi + trk.getTgl() * trk.getTgl());
112 auto cor = mLocalGain.
getValue(tracklet.getHCID() / 2, tracklet.getPadCol(mApplyShift), tracklet.getPadRow()) * trackletLength;
113 float q0{tracklet.getQ0() / cor}, q1{tracklet.getQ1() / cor}, q2{tracklet.getQ2() / cor};
116 if (trkTrd.getIsCrossingNeighbor(iLayer) && trkTrd.getHasNeighbor()) {
117 for (
const auto& trklt : mTrackletsRaw) {
118 if (tracklet.getTrackletWord() == trklt.getTrackletWord()) {
121 if (std::abs(tracklet.getPadCol(mApplyShift) - trklt.getPadCol(mApplyShift)) <= 1 && std::abs(tracklet.getPadRow() - trklt.getPadRow()) == 1) {
123 auto cor = mLocalGain.
getValue(trklt.getHCID() / 2, trklt.getPadCol(mApplyShift), trklt.getPadRow()) * trackletLength;
124 q0 += trklt.getQ0() / cor;
125 q1 += trklt.getQ1() / cor;
126 q2 += trklt.getQ2() / cor;
134 mTrackQC.push_back(qcStruct);