57 auto id = trkTrd.getRefGlobalTrackId();
63 LOGF(
debug,
"Got track with %i tracklets and ID %i", trkTrd.getNtracklets(), (
int)
id);
67 qcStruct.
dEdxTotTPC = isTPCTRD ? mTracksTPC[
id].getdEdx().dEdxTotTPC : mTracksTPC[mTracksITSTPC[
id].getRefTPC()].getdEdx().dEdxTotTPC;
70 for (
int iLayer = 0; iLayer <
NLAYER; ++iLayer) {
71 int trkltId = trkTrd.getTrackletIndex(iLayer);
75 const auto& tracklet = mTrackletsRaw[trkltId];
76 qcStruct.
trklt64[iLayer] = tracklet;
77 qcStruct.
trkltCalib[iLayer] = mTrackletsCalib[trkltId];
78 int trkltDet = tracklet.getDetector();
82 LOGF(
debug,
"Track could not be rotated in tracklet coordinate system");
86 if (!propagator->PropagateToXBxByBz(trk, mTrackletsCalib[trkltId].getX(), mMaxSnp, mMaxStep, mMatCorr)) {
87 LOGF(
debug,
"Track propagation failed in layer %i (pt=%f, xTrk=%f, xToGo=%f)", iLayer, trk.getPt(), trk.getX(), mTrackletsCalib[trkltId].getX());
91 float tilt = tan(TMath::DegToRad() * pad->getTiltingAngle());
92 float tiltCorrUp = tilt * (mTrackletsCalib[trkltId].getZ() - trk.getZ());
93 float zPosCorrUp = mTrackletsCalib[trkltId].getZ() + mRecoParam.getZCorrCoeffNRC() * trk.getTgl();
94 float padLength = pad->getRowSize(tracklet.getPadRow());
95 if (!((trk.getSigmaZ2() < (padLength * padLength / 12.f)) && (std::fabs(mTrackletsCalib[trkltId].getZ() - trk.getZ()) < padLength))) {
98 std::array<float, 2> trkltPosUp{mTrackletsCalib[trkltId].getY() - tiltCorrUp, zPosCorrUp};
99 std::array<float, 3> trkltCovUp;
100 mRecoParam.recalcTrkltCov(tilt, trk.getSnp(), pad->getRowSize(tracklet.getPadRow()), trkltCovUp);
101 auto chi2trklt = trk.getPredictedChi2(trkltPosUp, trkltCovUp);
104 qcStruct.
trackletY[iLayer] = trkltPosUp[0];
105 qcStruct.
trackletZ[iLayer] = trkltPosUp[1];
112 auto tphi = trk.getSnp() / std::sqrt((1.f - trk.getSnp()) * (1.f + trk.getSnp()));
113 auto trackletLength = std::sqrt(1.f + tphi * tphi + trk.getTgl() * trk.getTgl());
114 auto cor = mLocalGain.
getValue(tracklet.getHCID() / 2, tracklet.getPadCol(mApplyShift), tracklet.getPadRow()) * trackletLength;
115 float q0{tracklet.getQ0() / cor}, q1{tracklet.getQ1() / cor}, q2{tracklet.getQ2() / cor};
118 if (trkTrd.getIsCrossingNeighbor(iLayer) && trkTrd.getHasNeighbor()) {
119 for (
const auto& trklt : mTrackletsRaw) {
120 if (tracklet.getTrackletWord() == trklt.getTrackletWord()) {
123 if (std::abs(tracklet.getPadCol(mApplyShift) - trklt.getPadCol(mApplyShift)) <= 1 && std::abs(tracklet.getPadRow() - trklt.getPadRow()) == 1) {
125 auto cor = mLocalGain.
getValue(trklt.getHCID() / 2, trklt.getPadCol(mApplyShift), trklt.getPadRow()) * trackletLength;
126 q0 += trklt.getQ0() / cor;
127 q1 += trklt.getQ1() / cor;
128 q2 += trklt.getQ2() / cor;
136 mTrackQC.push_back(qcStruct);