Project
Loading...
Searching...
No Matches
Tracking.cxx
Go to the documentation of this file.
1// Copyright 2019-2020 CERN and copyright holders of ALICE O2.
2// See https://alice-o2.web.cern.ch/copyright for details of the copyright holders.
3// All rights not expressly granted are reserved.
4//
5// This software is distributed under the terms of the GNU General Public
6// License v3 (GPL Version 3), copied verbatim in the file "COPYING".
7//
8// In applying this license CERN does not waive the privileges and immunities
9// granted to it by virtue of its status as an Intergovernmental Organization
10// or submit itself to any jurisdiction.
11
15
16#include "TRDQC/Tracking.h"
19#include "TRDBase/Geometry.h"
20#include "TRDBase/PadPlane.h"
21#include <fairlogger/Logger.h>
22
23using namespace o2::trd;
24using namespace o2::trd::constants;
25
27{
28 mRecoParam.setBfield(o2::base::Propagator::Instance()->getNominalBz());
29}
30
32{
33 mTracksTPC = input.getTPCTracks();
34 mTracksITSTPC = input.getTPCITSTracks();
35 mTracksITSTPCTRD = input.getITSTPCTRDTracks<TrackTRD>();
36 mTracksTPCTRD = input.getTPCTRDTracks<TrackTRD>();
37 mTrackletsRaw = input.getTRDTracklets();
38 mTrackletsCalib = input.getTRDCalibratedTracklets();
39}
40
42{
43 for (const auto& trkTrd : mTracksTPCTRD) {
44 checkTrack(trkTrd, true);
45 }
46 for (const auto& trkTrd : mTracksITSTPCTRD) {
47 checkTrack(trkTrd, false);
48 }
49}
50
51void Tracking::checkTrack(const TrackTRD& trkTrd, bool isTPCTRD)
52{
53 auto propagator = o2::base::Propagator::Instance();
54 auto id = trkTrd.getRefGlobalTrackId();
55 TrackQC qcStruct;
56
57 qcStruct.refGlobalTrackId = id;
58 qcStruct.trackTRD = trkTrd;
59
60 LOGF(debug, "Got track with %i tracklets and ID %i", trkTrd.getNtracklets(), (int)id);
61 o2::track::TrackParCov trk = isTPCTRD ? mTracksTPC[id].getParamOut() : mTracksITSTPC[id].getParamOut();
62 qcStruct.trackSeed = trk;
63 if (mPID) {
64 qcStruct.dEdxTotTPC = isTPCTRD ? mTracksTPC[id].getdEdx().dEdxTotTPC : mTracksTPC[mTracksITSTPC[id].getRefTPC()].getdEdx().dEdxTotTPC;
65 }
66
67 for (int iLayer = 0; iLayer < NLAYER; ++iLayer) {
68 int trkltId = trkTrd.getTrackletIndex(iLayer);
69 if (trkltId < 0) {
70 continue;
71 }
72 const auto& tracklet = mTrackletsRaw[trkltId];
73 qcStruct.trklt64[iLayer] = tracklet;
74 qcStruct.trkltCalib[iLayer] = mTrackletsCalib[trkltId];
75 int trkltDet = tracklet.getDetector();
76 int trkltSec = trkltDet / (NLAYER * NSTACK);
77 if (trkltSec != o2::math_utils::angle2Sector(trk.getAlpha())) {
78 if (!trk.rotate(o2::math_utils::sector2Angle(trkltSec))) {
79 LOGF(debug, "Track could not be rotated in tracklet coordinate system");
80 break;
81 }
82 }
83 if (!propagator->PropagateToXBxByBz(trk, mTrackletsCalib[trkltId].getX(), mMaxSnp, mMaxStep, mMatCorr)) {
84 LOGF(debug, "Track propagation failed in layer %i (pt=%f, xTrk=%f, xToGo=%f)", iLayer, trk.getPt(), trk.getX(), mTrackletsCalib[trkltId].getX());
85 break;
86 }
87 const PadPlane* pad = Geometry::instance()->getPadPlane(trkltDet);
88 float tilt = tan(TMath::DegToRad() * pad->getTiltingAngle()); // tilt is signed! and returned in degrees
89 float tiltCorrUp = tilt * (mTrackletsCalib[trkltId].getZ() - trk.getZ());
90 float zPosCorrUp = mTrackletsCalib[trkltId].getZ() + mRecoParam.getZCorrCoeffNRC() * trk.getTgl();
91 float padLength = pad->getRowSize(tracklet.getPadRow());
92 if (!((trk.getSigmaZ2() < (padLength * padLength / 12.f)) && (std::fabs(mTrackletsCalib[trkltId].getZ() - trk.getZ()) < padLength))) {
93 tiltCorrUp = 0.f;
94 }
95 std::array<float, 2> trkltPosUp{mTrackletsCalib[trkltId].getY() - tiltCorrUp, zPosCorrUp};
96 std::array<float, 3> trkltCovUp;
97 mRecoParam.recalcTrkltCov(tilt, trk.getSnp(), pad->getRowSize(tracklet.getPadRow()), trkltCovUp);
98 auto chi2trklt = trk.getPredictedChi2(trkltPosUp, trkltCovUp);
99
100 qcStruct.trackProp[iLayer] = trk;
101 qcStruct.trackletY[iLayer] = trkltPosUp[0];
102 qcStruct.trackletZ[iLayer] = trkltPosUp[1];
103 qcStruct.trackletChi2[iLayer] = chi2trklt;
104
106 // To correct for longer drift lengths in the drfit chamber and hence more energy deposition,
107 // we calculate the variation to reference for the tracklets (exrapolated from the track fit).
108 // \sqrt{ (dx/dx)^2 + (dy/dx)^2 + (dz/dx)^2}
109 auto tphi = trk.getSnp() / std::sqrt((1.f - trk.getSnp()) * (1.f + trk.getSnp()));
110 auto trackletLength = std::sqrt(1.f + tphi * tphi + trk.getTgl() * trk.getTgl());
111 auto cor = mLocalGain.getValue(tracklet.getHCID() / 2, tracklet.getPadCol(mApplyShift), tracklet.getPadRow()) * trackletLength;
112 float q0{tracklet.getQ0() / cor}, q1{tracklet.getQ1() / cor}, q2{tracklet.getQ2() / cor};
113
114 // z-row merging
115 if (trkTrd.getIsCrossingNeighbor(iLayer) && trkTrd.getHasNeighbor()) {
116 for (const auto& trklt : mTrackletsRaw) {
117 if (tracklet.getTrackletWord() == trklt.getTrackletWord()) { // skip original tracklet
118 continue;
119 }
120 if (std::abs(tracklet.getPadCol(mApplyShift) - trklt.getPadCol(mApplyShift)) <= 1 && std::abs(tracklet.getPadRow() - trklt.getPadRow()) == 1) {
121 // Add charge information
122 auto cor = mLocalGain.getValue(trklt.getHCID() / 2, trklt.getPadCol(mApplyShift), trklt.getPadRow()) * trackletLength;
123 q0 += trklt.getQ0() / cor;
124 q1 += trklt.getQ1() / cor;
125 q2 += trklt.getQ2() / cor;
126 break;
127 }
128 }
129 }
130
131 qcStruct.trackletCorCharges[iLayer] = {q0, q1, q2};
132 }
133 mTrackQC.push_back(qcStruct);
134}
Wrapper container for different reconstructed object types.
Definition of the GeometryManager class.
Check the performance of the TRD in global tracking.
std::ostringstream debug
GPUd() value_type estimateLTFast(o2 static GPUd() float estimateLTIncrement(const o2 PropagatorImpl * Instance(bool uninitialized=false)
Definition Propagator.h:143
static Geometry * instance()
Definition Geometry.h:33
T getValue(int roc, int col, int row) const
void recalcTrkltCov(const float tilt, const float snp, const float rowSize, std::array< float, 3 > &cov) const
Recalculate tracklet covariance based on phi angle of related track.
Definition RecoParam.cxx:55
float getZCorrCoeffNRC() const
Get tracklet z correction coefficient for track-eta based corraction.
Definition RecoParam.h:49
void setBfield(float bz)
Load parameterization for given magnetic field.
Definition RecoParam.cxx:23
void setInput(const o2::globaltracking::RecoContainer &input)
Initialize the input arrays.
Definition Tracking.cxx:31
void run()
Main processing function.
Definition Tracking.cxx:41
void checkTrack(const TrackTRD &trk, bool isTPCTRD)
Check track QC.
Definition Tracking.cxx:51
void init()
Load geometry and apply magnetic field setting.
Definition Tracking.cxx:26
GLuint id
Definition glcorearb.h:650
int angle2Sector(float phi)
Definition Utils.h:183
float sector2Angle(int sect)
Definition Utils.h:193
TrackParCovF TrackParCov
Definition Track.h:33
constexpr int NLAYER
the number of layers
Definition Constants.h:27
constexpr int NSTACK
the number of stacks per sector
Definition Constants.h:26
gsl::span< const o2::trd::CalibratedTracklet > getTRDCalibratedTracklets() const
gsl::span< const o2::trd::Tracklet64 > getTRDTracklets() const
float dEdxTotTPC
raw total dEdx information for seeding track in TPC
Definition Tracking.h:54
std::array< o2::track::TrackPar, constants::NLAYER > trackProp
the track parameters stored at the radius where the track is updated with TRD info
Definition Tracking.h:56
GTrackID refGlobalTrackId
GlobalTrackID of the seeding track (either ITS-TPC or TPC)
Definition Tracking.h:51
std::array< float, constants::NLAYER > trackletChi2
estimated chi2 for the update of the track with the given tracklet
Definition Tracking.h:62
std::array< CalibratedTracklet, constants::NLAYER > trkltCalib
the TRD space point used for the update (not yet tilt-corrected and z-shift corrected)
Definition Tracking.h:58
TrackTRD trackTRD
the found TRD track
Definition Tracking.h:52
std::array< float, constants::NLAYER > trackletY
y-position of tracklet used for track update (including correction)
Definition Tracking.h:60
std::array< std::array< float, constants::NCHARGES >, constants::NLAYER > trackletCorCharges
corrected charges of tracklets
Definition Tracking.h:63
std::array< Tracklet64, constants::NLAYER > trklt64
the raw tracklet used for the update (includes uncorrected charges)
Definition Tracking.h:57
std::array< float, constants::NLAYER > trackletZ
z-position of tracklet used for track update (including correction)
Definition Tracking.h:61
o2::track::TrackParCov trackSeed
outer param of the seeding track
Definition Tracking.h:53