Project
Loading...
Searching...
No Matches
TrackInterpolation.h
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
16
17#ifndef ALICEO2_TPC_TRACKINTERPOLATION_H_
18#define ALICEO2_TPC_TRACKINTERPOLATION_H_
19
20#include <gsl/span>
42#include "GPUTRDRecoParam.h"
43#include "TRDBase/Geometry.h"
45
46class TTree;
47
48namespace o2
49{
50
51namespace gpu
52{
53class GPUParam;
54}
55
56namespace tpc
57{
58class VDriftCorrFact;
59
62 float dy{};
63 float dz{};
64 float y{};
65 float z{};
66 float snp{};
67 unsigned char sec{};
68 unsigned char dRow{};
70};
71
75 UnbinnedResid() = default;
76 UnbinnedResid(float dyIn, float dzIn, float tgSlpIn, float yIn, float zIn,
77 unsigned char rowIn, unsigned char secIn, short chanIn = -1, bool rejFlag = false) : dy(static_cast<short>(dyIn * 0x7fff / param::MaxResid)),
78 dz(static_cast<short>(dzIn * 0x7fff / param::MaxResid)),
79 tgSlp(static_cast<short>(tgSlpIn * 0x7fff / param::MaxTgSlp)),
80 y(static_cast<short>(yIn * 0x7fff / param::MaxY)),
81 z(static_cast<short>(zIn * 0x7fff / param::MaxZ)),
82 row(rowIn),
83 sec(secIn),
84 channel(chanIn),
85 rejected(rejFlag) {}
86 short dy{0};
87 short dz{0};
88 short tgSlp{0};
89 short y{0};
90 short z{0};
91 unsigned char row{0};
92 unsigned char sec{0};
93 short channel{-1};
94 bool rejected{false};
95
96 bool isTPC() const { return row < constants::MAXGLOBALPADROW; }
97 bool isTRD() const { return row >= 160 && row < 166; }
98 bool isTOF() const { return row == 170; }
99 bool isITS() const { return row >= 180; }
100 int getDetID() const { return isTPC() ? 1 : (isITS() ? 0 : (isTRD() ? 2 : (isTOF() ? 3 : -1))); }
101 int getITSLayer() const { return row - 180; }
102 int getTRDLayer() const { return row - 170; }
103 float getAlpha() const;
104 float getX() const;
105
106 static void init(long timestamp = -1);
107 static void checkInitDone();
108 static bool gInitDone;
109
111};
112
113struct DetInfoResid { // detector info associated with residual
114 uint32_t word = 0; // container interpreted in a different way depending on the detector type
115 //
116 // TPC view: qTot and qMax of the cluster
117 uint16_t qTotTPC() const { return static_cast<uint16_t>(word & 0xFFFFu); }
118 uint16_t qMaxTPC() const { return static_cast<uint16_t>((word >> 16) & 0xFFFFu); }
119 void setTPC(uint16_t qTot, uint16_t qMax) { word = (static_cast<uint32_t>(qMax) << 16) | static_cast<uint32_t>(qTot); }
120 //
121 // TRD view: q0, q1, q2 + calibrated slope (truncated to in +-3.5 range)
122 static constexpr uint32_t TRDQ0NB = 7, TRDQ1NB = 7, TRDQ2NB = 6, TRDSlpNB = 12;
123 static constexpr uint32_t TRDQ0Msk = (1 << TRDQ0NB) - 1, TRDQ1Msk = (1 << TRDQ1NB) - 1, TRDQ2Msk = ((1 << TRDQ2NB) - 1), TRDSlpMsk = (1 << TRDSlpNB) - 1;
124 static constexpr float TRDMaxSlope = 3.5, TRDSlope2Int = ((1 << TRDSlpNB) - 1) / (2 * TRDMaxSlope), TRDInt2Slope = 1.f / TRDSlope2Int;
125 uint16_t q0TRD() const { return static_cast<uint16_t>(word & TRDQ0Msk); }
126 uint16_t q1TRD() const { return static_cast<uint16_t>((word >> TRDQ0NB) & TRDQ1Msk); }
127 uint16_t q2TRD() const { return static_cast<uint16_t>((word >> (TRDQ0NB + TRDQ1NB)) & TRDQ2Msk); }
128 float slopeTRD() const { return ((word >> (TRDQ0NB + TRDQ1NB + TRDQ2NB)) & TRDSlpMsk) * TRDInt2Slope - TRDMaxSlope; }
129 void setTRD(uint8_t q0, uint8_t q1, uint8_t q2, float slope)
130 {
131 float rslope = (slope + TRDMaxSlope) * TRDSlope2Int;
132 if (rslope < 0.f) {
133 rslope = 0;
134 } else if (rslope > TRDSlpMsk) {
135 rslope = TRDSlpMsk;
136 }
137 uint32_t slpI = std::round(rslope);
138 word = (static_cast<uint32_t>(slpI << (TRDQ0NB + TRDQ1NB + TRDQ2NB)) |
139 static_cast<uint32_t>((q2 & TRDQ2Msk) << (TRDQ0NB + TRDQ1NB)) |
140 static_cast<uint32_t>((q1 & TRDQ1Msk) << TRDQ0NB) |
141 static_cast<uint32_t>(q0 & TRDQ0Msk));
142 }
143 //
144 // TOF view (time difference in \mus wrt seeding ITS-TPC track)
145 float timeTOF() const { return std::bit_cast<float>(word); }
146 void setTOF(float t) { word = std::bit_cast<uint32_t>(t); }
147 //
148 // No info for ITS is stored
149 //
150 // PV view (time difference in \mus wrt contributing ITS-TPC track)
151 float timePV() const { return std::bit_cast<float>(word); }
152 void setPV(float t) { word = std::bit_cast<uint32_t>(t); }
153
155};
156
159 TrackDataCompact() = default;
160 TrackDataCompact(uint32_t idx, std::array<uint8_t, 4> mlt, uint8_t nRes, uint8_t source, uint8_t nextraRes = 0, int8_t filt = -1) : idxFirstResidual(idx), multStack{mlt}, nResiduals(nRes), sourceId(source), filterFlag(filt), nExtDetResid(nextraRes) {}
162 std::array<uint8_t, 4> multStack{}; // multiplicity in the stack packed as asinh(x*0.05)/0.05
163 uint8_t nResiduals;
164 uint8_t nExtDetResid = 0;
165 uint8_t sourceId;
166 int8_t filterFlag = -1;
167
168 void setMultStack(float v, int stack)
169 {
170 uint32_t mltPacked = std::round(std::asinh(v * 0.05) / 0.05);
171 multStack[stack] = mltPacked < 0xff ? mltPacked : 0xff;
172 }
173 float getMultStack(int stack) const
174 {
175 return std::sinh(multStack[stack] * 0.05) / 0.05;
176 }
177 float getMultStackPacked(int stack) const { return multStack[stack]; }
178
180};
181
182// TODO add to UnbinnedResid::sec flag if cluster was used or not
183// TODO add to TrackDataCompact::sourceId flag if track was used or not (if possible)
184
202
204struct TrackData {
207 float dEdxTPC{};
208 float chi2TPC{};
209 float chi2ITS{};
210 float chi2TRD{};
211 float deltaTOF{};
212
213 unsigned short nClsTPC{};
214 unsigned short nClsITS{};
215 unsigned short nTrkltsTRD{};
216 unsigned short clAvailTOF{};
217 short TRDTrkltSlope[6] = {};
218 uint8_t nExtDetResid = 0;
219 int8_t filterFlag = -1;
221 std::array<uint8_t, 4> multStack{}; // multiplicity in the stack packed as asinh(x*0.05)/0.05
222 float getT0Error() const { return float(clAvailTOF); }
223 bool isTOFAvail() const { return clAvailTOF != 0; }
224
225 void setMultStack(float v, int stack)
226 {
227 uint32_t mltPacked = std::round(std::asinh(v * 0.05) / 0.05);
228 multStack[stack] = mltPacked < 0xff ? mltPacked : 0xff;
229 }
230 float getMultStack(int stack) const
231 {
232 return std::sinh(multStack[stack] * 0.05) / 0.05;
233 }
234 float getMultStackPacked(int stack) const { return multStack[stack]; }
235
237};
238
244{
245 public:
247
250
251 // since this class has pointer members, we should explicitly delete copy and assignment operators
254
256
258 enum {
259 ExtOut = 0,
262 NIndices
263 };
264
266 struct CacheStruct {
267 std::array<float, NIndices> y{};
268 std::array<float, NIndices> z{};
269 std::array<float, NIndices> sy2{};
270 std::array<float, NIndices> szy{};
271 std::array<float, NIndices> sz2{};
272 std::array<float, NIndices> snp{};
273 float clY{0.f};
274 float clZ{0.f};
275 float clAngle{0.f};
276 unsigned short clAvailable{0};
277 unsigned char clSec{0};
278 };
279
282 float xTrk{0.f};
283 float yTrk{0.f};
284 float zTrk{0.f};
285 float xLab{0.f};
286 float yLab{0.f};
287 float sPath{0.f};
288 float dy{0.f};
289 float dz{0.f};
290 float tglArr{0.f};
291 float residHelixY{0.f};
292 float residHelixZ{0.f};
293 float diffYSmooth{0.f};
294 float diffZSmooth{0.f};
295 int8_t sec{0};
296 bool flagRej{false};
298 };
299
301 float qpt{0.f};
302 float tgl{0.f};
303 float xcLab{0.f};
304 float ycLab{0.f};
305 float r{0.f};
306 float zOffs{0.f};
307 uint8_t nRej = 0;
308 std::vector<ValidationPoint> points;
309 void clear()
310 {
311 points.clear();
312 nRej = 0;
313 }
315 };
316
317 // -------------------------------------- processing functions --------------------------------------------------
318
321
324
327
330
332 bool isTrackSelected(const o2::track::TrackParCov& trk) const;
333
335 void process();
336
339 void extrapolateTrack(int iSeed);
340
343 void interpolateTrack(int iSeed);
344
346 void reset();
347
348 // refit ITS track taking PID (unless already refitted) from the seed and reassign to the seed
350 // -------------------------------------- outlier rejection --------------------------------------------------
351
356 int8_t validateTrack(const TrackData& trk, TrackValidationData& params, const std::vector<TPCClusterResiduals>& clsRes, bool interpol);
357
360 bool outlierFiltering(const TrackData& trk, TrackValidationData& params, const std::vector<TPCClusterResiduals>& clsRes);
361
364 float checkResiduals(const TrackData& trk, TrackValidationData& params, const std::vector<TPCClusterResiduals>& clsRes);
365
368 bool compareToHelix(const TrackData& trk, TrackValidationData& params, const std::vector<TPCClusterResiduals>& clsRes);
369
371 void diffToLocLine(TrackValidationData& params, int start, int np);
372
374 void diffToMA(const int np, const std::array<float, param::NPadRows>& y, std::array<float, param::NPadRows>& diffMA);
375
376 // -------------------------------------- settings --------------------------------------------------
377 void setNHBPerTF(int n) { mNHBPerTF = n; }
378
380
382 void setMatCorr(MatCorrType matCorr) { mMatCorr = matCorr; }
383
385 void setMaxTracksPerTF(int n) { mMaxTracksPerTF = n; }
386
388 void setAddTracksForMapPerTF(int n) { mAddTracksForMapPerTF = n; }
389
391 void setDumpTrackPoints() { mDumpTrackPoints = true; }
392
394 void setITSClusterDictionary(const o2::itsmft::TopologyDictionary* dict) { mITSDict = dict; }
395
397 void setProcessSeeds() { mProcessSeeds = true; }
398
400 void setProcessITSTPConly() { mProcessITSTPConly = true; }
401
403 void setSqrtS(float s) { mSqrtS = s; }
404
405 void setExtDetResid(bool v) { mExtDetResid = v; }
406
407 int processTRDLayer(const o2::trd::TrackTRD& trkTRD, int iLayer, o2::track::TrackParCov& trkWork, std::array<float, 2>* trkltTRDYZ = nullptr,
408 std::array<float, 3>* trkltTRDCov = nullptr, TrackData* trkData = nullptr,
409 o2::trd::Tracklet64* trk64 = nullptr, o2::trd::CalibratedTracklet* trkCalib = nullptr);
410
411 // --------------------------------- output ---------------------------------------------
412 std::vector<UnbinnedResid>& getClusterResiduals() { return mClRes; }
413 std::vector<DetInfoResid>& getClusterResidualsDetInfo() { return mDetInfoRes; }
414 std::vector<TrackDataCompact>& getTrackDataCompact() { return mTrackDataCompact; }
415 std::vector<TrackDataExtended>& getTrackDataExtended() { return mTrackDataExtended; }
416 std::vector<TrackData>& getReferenceTracks() { return mTrackData; }
417
418 void setLane(int lID, int nL)
419 {
420 mLaneID = lID;
421 mNLanes = nL;
422 }
423
424 void finalize();
425
426 private:
427 static constexpr float sFloatEps{1.e-7f};
428 static constexpr int NSTACKS = 4;
429 static constexpr std::array<int, NSTACKS + 1> STACKROWS{0, 63, 97, 127, 152};
430 // parameters + settings
431 const SpacePointsCalibConfParam* mParams = nullptr;
432 std::shared_ptr<o2::gpu::GPUParam> mTPCParam = nullptr;
433 int mLaneID = 0;
434 int mNLanes = 1;
435 int mNHBPerTF = 32;
436 int mNTPCOccBinLength = 16;
437 float mNTPCOccBinLengthInv = 1.f / 16;
438 float mTPCTimeBinMUS{.2f};
439 float mTPCVDriftRef = -1.;
440 float mTPCDriftTimeOffsetRef = 0.;
441 float mSqrtS{13600.f};
442 MatCorrType mMatCorr{MatCorrType::USEMatCorrNONE};
443 int mMaxTracksPerTF{-1};
444 int mAddTracksForMapPerTF{0};
445 bool mDumpTrackPoints{false};
446 bool mExtDetResid{true};
447 bool mProcessSeeds{false};
448 bool mProcessITSTPConly{false};
449 o2::dataformats::GlobalTrackID::mask_t mSourcesConfigured;
450 o2::dataformats::GlobalTrackID::mask_t mSourcesConfiguredMap;
451 bool mSingleSourcesConfigured{true};
452
453 // input
454 const o2::globaltracking::RecoContainer* mRecoCont = nullptr;
455 std::vector<o2::dataformats::GlobalTrackID> mGIDs{};
456 std::vector<o2::globaltracking::RecoContainer::GlobalIDSet> mGIDtables{};
457 std::vector<float> mTrackTimes{};
458 std::vector<int> mTrackPVID{};
459 std::vector<o2::track::TrackParCov> mSeeds{};
460 std::vector<int> mParentID{};
461 std::map<int, int> mTrackTypes;
462 std::array<std::vector<uint32_t>, 4> mTrackIndices;
463 gsl::span<const TPCClRefElem> mTPCTracksClusIdx;
464 const ClusterNativeAccess* mTPCClusterIdxStruct = nullptr;
465 // ITS specific input only needed for debugging
466 gsl::span<const int> mITSTrackClusIdx;
467 std::vector<o2::BaseCluster<float>> mITSClustersArray;
468 std::vector<int> mITSRefitSeedID;
469 const o2::itsmft::TopologyDictionary* mITSDict = nullptr;
470
471 // output
472 std::vector<TrackData> mTrackData{};
473 std::vector<TrackDataCompact> mTrackDataCompact{};
474 std::vector<TrackDataExtended> mTrackDataExtended{};
475 std::vector<UnbinnedResid> mClRes{};
476 std::vector<DetInfoResid> mDetInfoRes{};
477 std::unique_ptr<o2::utils::TreeStreamRedirector> mDBGOut;
478
479 // cache
480 std::array<CacheStruct, constants::MAXGLOBALPADROW> mCache{{}};
481 std::vector<o2::dataformats::GlobalTrackID> mGIDsSuccess;
482
483 TrackValidationData mTrackValidation;
484
485 // helpers
486 o2::gpu::GPUTRDRecoParam mRecoParam;
487 o2::trd::Geometry* mGeoTRD;
488 std::unique_ptr<TPCFastTransform> mFastTransform{};
489 float mBz;
490 bool mInitDone{false};
491 size_t mRejectedResiduals{};
492 size_t mNRejRefit = 0;
493 size_t mNRejProp = 0;
494 size_t mNRejLoop = 0;
495
496 ClassDefNV(TrackInterpolation, 1);
497};
498
499} // namespace tpc
500
501} // namespace o2
502
503#endif
Wrapper container for different reconstructed object types.
Definition of the ITSMFT cluster.
Definition of the ClusterTopology class.
Definition of the TOF cluster.
Base track model for the Barrel, params only, w/o covariance.
Class to store event ID and index in the event for objects like track, cluster...
Global index for barrel track: provides provenance (detectors combination), index in respective array...
Class to store the output of the matching to TOF.
Class to refer to the 1st entry and N elements of some group in the continuous container.
uint16_t slope
Definition RawData.h:1
uint32_t stack
Definition RawData.h:1
Parameters used for TPC space point calibration.
class to create TPC fast transformation
Definition of the ITS track.
Result of refitting TPC-ITS matched track.
Reference on ITS/MFT clusters set.
Cluster class for TOF.
Definition Cluster.h:37
float checkResiduals(const TrackData &trk, TrackValidationData &params, const std::vector< TPCClusterResiduals > &clsRes)
TrackInterpolation(const TrackInterpolation &)=delete
void prepareInputTrackSample(const o2::globaltracking::RecoContainer &inp)
Prepare input track sample (not relying on CreateTracksVariadic functionality)
int processTRDLayer(const o2::trd::TrackTRD &trkTRD, int iLayer, o2::track::TrackParCov &trkWork, std::array< float, 2 > *trkltTRDYZ=nullptr, std::array< float, 3 > *trkltTRDCov=nullptr, TrackData *trkData=nullptr, o2::trd::Tracklet64 *trk64=nullptr, o2::trd::CalibratedTracklet *trkCalib=nullptr)
bool isInputTrackAccepted(const o2::dataformats::GlobalTrackID &gid, const o2::globaltracking::RecoContainer::GlobalIDSet &gidTable, const o2::dataformats::PrimaryVertex &pv) const
Check if input track passes configured cuts.
std::vector< TrackData > & getReferenceTracks()
TrackInterpolation()=default
Default constructor.
std::vector< TrackDataExtended > & getTrackDataExtended()
o2::dataformats::GlobalTrackID::Source findValidSource(const o2::dataformats::GlobalTrackID::mask_t mask, const o2::dataformats::GlobalTrackID::Source src) const
For given vertex track source which is not in mSourcesConfigured find the seeding source which is ena...
void setMatCorr(MatCorrType matCorr)
Sets the flag if material correction should be applied when extrapolating the tracks.
void setProcessSeeds()
Enable processing of seeds.
void setMaxTracksPerTF(int n)
Sets the maximum number of tracks to be processed (successfully) per TF.
bool refITSTrack(o2::dataformats::GlobalTrackID, int iSeed)
std::vector< TrackDataCompact > & getTrackDataCompact()
void setAddTracksForMapPerTF(int n)
In addition to mMaxTracksPerTF up to the set number of additional tracks can be processed.
@ ExtIn
extrapolation inwards of TRD/TOF track
@ NIndices
total number of indices (3)
@ Int
interpolation (mean positions of both extrapolations)
@ ExtOut
extrapolation outwards of ITS track
void setLane(int lID, int nL)
std::vector< DetInfoResid > & getClusterResidualsDetInfo()
void diffToMA(const int np, const std::array< float, param::NPadRows > &y, std::array< float, param::NPadRows > &diffMA)
For a given set of points, calculate their deviation from the moving average (build from the neighbou...
bool compareToHelix(const TrackData &trk, TrackValidationData &params, const std::vector< TPCClusterResiduals > &clsRes)
void diffToLocLine(TrackValidationData &params, int start, int np)
For a given set of points, calculate the differences from each point to the fitted lines from all oth...
void process()
Main processing function.
void setITSClusterDictionary(const o2::itsmft::TopologyDictionary *dict)
Allow setting the ITS cluster dictionary from outside.
std::vector< UnbinnedResid > & getClusterResiduals()
TrackInterpolation & operator=(const TrackInterpolation &)=delete
void setDumpTrackPoints()
Enable full output.
void setTPCVDrift(const o2::tpc::VDriftCorrFact &v)
void setProcessITSTPConly()
Enable ITS-TPC only processing.
int8_t validateTrack(const TrackData &trk, TrackValidationData &params, const std::vector< TPCClusterResiduals > &clsRes, bool interpol)
void setSqrtS(float s)
Set the centre of mass energy required for pT downsampling Tsalis function.
bool isTrackSelected(const o2::track::TrackParCov &trk) const
Given the defined downsampling factor tsalisThreshold check if track is selected.
void reset()
Reset cache and output vectors.
bool outlierFiltering(const TrackData &trk, TrackValidationData &params, const std::vector< TPCClusterResiduals > &clsRes)
void init(o2::dataformats::GlobalTrackID::mask_t src, o2::dataformats::GlobalTrackID::mask_t srcMap)
Initialize everything, set the requested track sources.
GLdouble n
Definition glcorearb.h:1982
GLenum src
Definition glcorearb.h:1767
const GLdouble * v
Definition glcorearb.h:832
GLsizei GLsizei GLchar * source
Definition glcorearb.h:798
GLenum const GLfloat * params
Definition glcorearb.h:272
GLboolean r
Definition glcorearb.h:1233
GLuint start
Definition glcorearb.h:469
GLenum GLfloat param
Definition glcorearb.h:271
GLint GLuint mask
Definition glcorearb.h:291
GLdouble GLdouble GLdouble z
Definition glcorearb.h:843
constexpr int MAXGLOBALPADROW
Definition Constants.h:34
TrackParCovF TrackParCov
Definition Track.h:33
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
std::array< GTrackID, GTrackID::NSources > GlobalIDSet
static constexpr uint32_t TRDQ2Msk
ClassDefNV(DetInfoResid, 1)
static constexpr float TRDSlope2Int
static constexpr uint32_t TRDQ1Msk
static constexpr uint32_t TRDSlpMsk
static constexpr uint32_t TRDQ0NB
static constexpr uint32_t TRDQ2NB
void setTRD(uint8_t q0, uint8_t q1, uint8_t q2, float slope)
static constexpr float TRDInt2Slope
static constexpr float TRDMaxSlope
void setTPC(uint16_t qTot, uint16_t qMax)
static constexpr uint32_t TRDQ1NB
static constexpr uint32_t TRDQ0Msk
static constexpr uint32_t TRDSlpNB
Internal struct used to store the unbinned TPC cluster residuals with float values.
ClassDefNV(TPCClusterResiduals, 5)
unsigned char dRow
distance to previous row in units of pad rows
unsigned char sec
sector number 0..35
float snp
sin of the phi angle between padrow and track
Structure for the information required to associate each residual with a given track type (ITS-TPC-TR...
uint8_t nResiduals
total number of TPC residuals associated to this track
uint8_t sourceId
source ID obtained from the global track ID
uint8_t nExtDetResid
number of external detectors (wrt TPC) residuals stored, on top of clIdx.getEntries
std::array< uint8_t, 4 > multStack
void setMultStack(float v, int stack)
TrackDataCompact(uint32_t idx, std::array< uint8_t, 4 > mlt, uint8_t nRes, uint8_t source, uint8_t nextraRes=0, int8_t filt=-1)
float getMultStack(int stack) const
ClassDefNV(TrackDataCompact, 4)
float getMultStackPacked(int stack) const
int8_t filterFlag
-1: validation was not done, 0: validated, >0 : reason not passing validation, see validateTrack meth...
uint32_t idxFirstResidual
the index of the first residual from this track
Heavy structure with track parameterizations + track points for debugging.
o2::dataformats::RangeReference clIdx
index of first cluster residual and total number of cluster residuals of this track
std::vector< o2::trd::CalibratedTracklet > clsTRD
the TRD space points (if available)
o2::dataformats::MatchInfoTOF matchTOF
TOF matching information.
o2::track::TrackPar trkOuter
refit of TRD and/or TOF points
o2::its::TrackITS trkITS
ITS seeding track.
uint8_t nExtDetResid
number of external detectors (to TPC) residuals stored, on top of clIdx.getEntries
o2::trd::TrackTRD trkTRD
TRD seeding track.
std::vector< o2::trd::Tracklet64 > trkltTRD
attached TRD tracklets (if available)
ClassDefNV(TrackDataExtended, 4)
o2::dataformats::GlobalTrackID gid
GID of the most global barrel track.
o2::tpc::TrackTPC trkTPC
TPC track (including dEdx information)
int8_t filterFlag
-1: validation was not done, 0: validated, >0 : reason not passing validation, see validateTrack meth...
std::vector< o2::BaseCluster< float > > clsITS
attached ITS clusters
o2::tof::Cluster clsTOF
the TOF cluster (if available)
Structure filled for each track with track quality information and a vector with TPCClusterResiduals.
float chi2TRD
chi2 of TRD track
float dEdxTPC
TPC dEdx information.
unsigned short nTrkltsTRD
number of attached TRD tracklets
float getMultStackPacked(int stack) const
unsigned short clAvailTOF
whether or not track seed has a matched TOF cluster, if so, gives the resolution of the T0 in ps
std::array< uint8_t, 4 > multStack
short TRDTrkltSlope[6]
TRD tracklet slope 0x7fff / param::MaxTRDSlope.
unsigned short nClsITS
number of attached ITS clusters
o2::dataformats::RangeReference clIdx
index of first cluster residual and total number of TPC cluster residuals of this track
float chi2TPC
chi2 of TPC track
o2::track::TrackParCov par
ITS track at inner TPC radius.
unsigned short nClsTPC
number of attached TPC clusters
void setMultStack(float v, int stack)
float getMultStack(int stack) const
ClassDefNV(TrackData, 12)
o2::dataformats::GlobalTrackID gid
global track ID for seeding track
float deltaTOF
TOFsignal - T0 - texp(PID), if T0 is available.
int8_t filterFlag
-1: validation was not done, 0: validated, >0 : reason not passing validation, see validateTrack meth...
uint8_t nExtDetResid
number of external detectors (to TPC) residuals stored, on top of clIdx.getEntries
float chi2ITS
chi2 of ITS track
Structure for caching positions, covariances and angles for extrapolations from ITS and TRD/TOF and f...
Structure for on-the-fly re-calculated track parameters at the validation stage.
ClassDefNV(UnbinnedResid, 3)
bool rejected
residual is flagged as rejected in the validateTrack
unsigned char sec
TPC sector (0..35)
UnbinnedResid(float dyIn, float dzIn, float tgSlpIn, float yIn, float zIn, unsigned char rowIn, unsigned char secIn, short chanIn=-1, bool rejFlag=false)
unsigned char row
TPC pad row.
short tgSlp
tan of the phi angle between padrow and track
static void init(long timestamp=-1)
short channel
extra channel info (ITS chip ID, TRD chamber, TOF main pad within the sector)