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
17#include "TRDQC/Tracking.h"
20#include "TRDBase/Geometry.h"
21#include "TRDBase/PadPlane.h"
22#include <fairlogger/Logger.h>
23
24using namespace o2::trd;
25using namespace o2::trd::constants;
26
28{
29 mRecoParam.init(o2::base::Propagator::Instance()->getNominalBz());
30}
31
33{
34 mTracksTPC = input.getTPCTracks();
35 mTracksITSTPC = input.getTPCITSTracks();
36 mTracksITSTPCTRD = input.getITSTPCTRDTracks<TrackTRD>();
37 mTracksTPCTRD = input.getTPCTRDTracks<TrackTRD>();
38 mTrackletsRaw = input.getTRDTracklets();
39 mTrackletsCalib = input.getTRDCalibratedTracklets();
40}
41
43{
44 for (const auto& trkTrd : mTracksTPCTRD) {
45 checkTrack(trkTrd, true);
46 }
47 for (const auto& trkTrd : mTracksITSTPCTRD) {
48 checkTrack(trkTrd, false);
49 }
50}
51
52void Tracking::checkTrack(const TrackTRD& trkTrd, bool isTPCTRD)
53{
54 auto propagator = o2::base::Propagator::Instance();
55 auto id = trkTrd.getRefGlobalTrackId();
56 TrackQC qcStruct;
57
58 qcStruct.refGlobalTrackId = id;
59 qcStruct.trackTRD = trkTrd;
60
61 LOGF(debug, "Got track with %i tracklets and ID %i", trkTrd.getNtracklets(), (int)id);
62 o2::track::TrackParCov trk = isTPCTRD ? mTracksTPC[id].getParamOut() : mTracksITSTPC[id].getParamOut();
63 qcStruct.trackSeed = trk;
64 if (mPID) {
65 qcStruct.dEdxTotTPC = isTPCTRD ? mTracksTPC[id].getdEdx().dEdxTotTPC : mTracksTPC[mTracksITSTPC[id].getRefTPC()].getdEdx().dEdxTotTPC;
66 }
67
68 for (int iLayer = 0; iLayer < NLAYER; ++iLayer) {
69 int trkltId = trkTrd.getTrackletIndex(iLayer);
70 if (trkltId < 0) {
71 continue;
72 }
73 const auto& tracklet = mTrackletsRaw[trkltId];
74 qcStruct.trklt64[iLayer] = tracklet;
75 qcStruct.trkltCalib[iLayer] = mTrackletsCalib[trkltId];
76 int trkltDet = tracklet.getDetector();
77 int trkltSec = trkltDet / (NLAYER * NSTACK);
78 if (trkltSec != o2::math_utils::angle2Sector(trk.getAlpha())) {
79 if (!trk.rotate(o2::math_utils::sector2Angle(trkltSec))) {
80 LOGF(debug, "Track could not be rotated in tracklet coordinate system");
81 break;
82 }
83 }
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());
86 break;
87 }
88 const PadPlane* pad = Geometry::instance()->getPadPlane(trkltDet);
89 float tilt = tan(TMath::DegToRad() * pad->getTiltingAngle()); // tilt is signed! and returned in degrees
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))) {
94 tiltCorrUp = 0.f;
95 }
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);
100
101 qcStruct.trackProp[iLayer] = trk;
102 qcStruct.trackletY[iLayer] = trkltPosUp[0];
103 qcStruct.trackletZ[iLayer] = trkltPosUp[1];
104 qcStruct.trackletChi2[iLayer] = chi2trklt;
105
107 // To correct for longer drift lengths in the drfit chamber and hence more energy deposition,
108 // we calculate the variation to reference for the tracklets (exrapolated from the track fit).
109 // \sqrt{ (dx/dx)^2 + (dy/dx)^2 + (dz/dx)^2}
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};
114
115 // z-row merging
116 if (trkTrd.getIsCrossingNeighbor(iLayer) && trkTrd.getHasNeighbor()) {
117 for (const auto& trklt : mTrackletsRaw) {
118 if (tracklet.getTrackletWord() == trklt.getTrackletWord()) { // skip original tracklet
119 continue;
120 }
121 if (std::abs(tracklet.getPadCol(mApplyShift) - trklt.getPadCol(mApplyShift)) <= 1 && std::abs(tracklet.getPadRow() - trklt.getPadRow()) == 1) {
122 // Add charge information
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;
127 break;
128 }
129 }
130 }
131
132 qcStruct.trackletCorCharges[iLayer] = {q0, q1, q2};
133 }
134 mTrackQC.push_back(qcStruct);
135}
Wrapper container for different reconstructed object types.
Definition of the GeometryManager class.
std::ostringstream debug
Check the performance of the TRD in global tracking.
GPUd() value_type estimateLTFast(o2 static GPUd() float estimateLTIncrement(const o2 PropagatorImpl * Instance(bool uninitialized=false)
Definition Propagator.h:178
void init(float bz, const GPUSettingsRec *rec=nullptr)
Load parameterization for given magnetic field.
static Geometry * instance()
Definition Geometry.h:33
T getValue(int roc, int col, int row) const
void setInput(const o2::globaltracking::RecoContainer &input)
Initialize the input arrays.
Definition Tracking.cxx:32
void run()
Main processing function.
Definition Tracking.cxx:42
void checkTrack(const TrackTRD &trk, bool isTPCTRD)
Check track QC.
Definition Tracking.cxx:52
void init()
Load geometry and apply magnetic field setting.
Definition Tracking.cxx:27
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