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{
30 config.ReadConfigurableParam(config);
31 mRecoParam.init(o2::base::Propagator::Instance()->getNominalBz(), &config.configReconstruction);
32}
33
35{
36 mTracksTPC = input.getTPCTracks();
37 mTracksITSTPC = input.getTPCITSTracks();
38 mTracksITSTPCTRD = input.getITSTPCTRDTracks<TrackTRD>();
39 mTracksTPCTRD = input.getTPCTRDTracks<TrackTRD>();
40 mTrackletsRaw = input.getTRDTracklets();
41 mTrackletsCalib = input.getTRDCalibratedTracklets();
42}
43
45{
46 for (const auto& trkTrd : mTracksTPCTRD) {
47 checkTrack(trkTrd, true);
48 }
49 for (const auto& trkTrd : mTracksITSTPCTRD) {
50 checkTrack(trkTrd, false);
51 }
52}
53
54void Tracking::checkTrack(const TrackTRD& trkTrd, bool isTPCTRD)
55{
56 auto propagator = o2::base::Propagator::Instance();
57 auto id = trkTrd.getRefGlobalTrackId();
58 TrackQC qcStruct;
59
60 qcStruct.refGlobalTrackId = id;
61 qcStruct.trackTRD = trkTrd;
62
63 LOGF(debug, "Got track with %i tracklets and ID %i", trkTrd.getNtracklets(), (int)id);
64 o2::track::TrackParCov trk = isTPCTRD ? mTracksTPC[id].getParamOut() : mTracksITSTPC[id].getParamOut();
65 qcStruct.trackSeed = trk;
66 if (mPID) {
67 qcStruct.dEdxTotTPC = isTPCTRD ? mTracksTPC[id].getdEdx().dEdxTotTPC : mTracksTPC[mTracksITSTPC[id].getRefTPC()].getdEdx().dEdxTotTPC;
68 }
69
70 for (int iLayer = 0; iLayer < NLAYER; ++iLayer) {
71 int trkltId = trkTrd.getTrackletIndex(iLayer);
72 if (trkltId < 0) {
73 continue;
74 }
75 const auto& tracklet = mTrackletsRaw[trkltId];
76 qcStruct.trklt64[iLayer] = tracklet;
77 qcStruct.trkltCalib[iLayer] = mTrackletsCalib[trkltId];
78 int trkltDet = tracklet.getDetector();
79 int trkltSec = trkltDet / (NLAYER * NSTACK);
80 if (trkltSec != o2::math_utils::angle2Sector(trk.getAlpha())) {
81 if (!trk.rotate(o2::math_utils::sector2Angle(trkltSec))) {
82 LOGF(debug, "Track could not be rotated in tracklet coordinate system");
83 break;
84 }
85 }
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());
88 break;
89 }
90 const PadPlane* pad = Geometry::instance()->getPadPlane(trkltDet);
91 float tilt = tan(TMath::DegToRad() * pad->getTiltingAngle()); // tilt is signed! and returned in degrees
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))) {
96 tiltCorrUp = 0.f;
97 }
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);
102
103 qcStruct.trackProp[iLayer] = trk;
104 qcStruct.trackletY[iLayer] = trkltPosUp[0];
105 qcStruct.trackletZ[iLayer] = trkltPosUp[1];
106 qcStruct.trackletChi2[iLayer] = chi2trklt;
107
109 // To correct for longer drift lengths in the drfit chamber and hence more energy deposition,
110 // we calculate the variation to reference for the tracklets (exrapolated from the track fit).
111 // \sqrt{ (dx/dx)^2 + (dy/dx)^2 + (dz/dx)^2}
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};
116
117 // z-row merging
118 if (trkTrd.getIsCrossingNeighbor(iLayer) && trkTrd.getHasNeighbor()) {
119 for (const auto& trklt : mTrackletsRaw) {
120 if (tracklet.getTrackletWord() == trklt.getTrackletWord()) { // skip original tracklet
121 continue;
122 }
123 if (std::abs(tracklet.getPadCol(mApplyShift) - trklt.getPadCol(mApplyShift)) <= 1 && std::abs(tracklet.getPadRow() - trklt.getPadRow()) == 1) {
124 // Add charge information
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;
129 break;
130 }
131 }
132 }
133
134 qcStruct.trackletCorCharges[iLayer] = {q0, q1, q2};
135 }
136 mTrackQC.push_back(qcStruct);
137}
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:34
void run()
Main processing function.
Definition Tracking.cxx:44
void checkTrack(const TrackTRD &trk, bool isTPCTRD)
Check track QC.
Definition Tracking.cxx:54
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