Project
Loading...
Searching...
No Matches
GPUTPCGMSectorTrack.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
14
15#ifndef GPUTPCGMSECTORTRACK_H
16#define GPUTPCGMSECTORTRACK_H
17
18#include "GPUTPCTrack.h"
19#include "GPUTPCGMTrackParam.h"
20#include "GPUCommonMath.h"
21#include "GPUO2DataTypes.h"
22
23namespace o2::gpu
24{
30class GPUTPCGMMerger;
32{
33 public:
34 GPUd() float Alpha() const { return mAlpha; }
35 GPUd() uint8_t Sector() const { return mSector; }
36 GPUd() bool CSide() const { return mSector >= 18; }
37 GPUd() int32_t NClusters() const { return mNClusters; }
38 GPUd() int32_t PrevNeighbour() const { return mNeighbour[0]; }
39 GPUd() int32_t NextNeighbour() const { return mNeighbour[1]; }
40 GPUd() int32_t Neighbour(int32_t i) const { return mNeighbour[i]; }
41 GPUd() int32_t PrevSegmentNeighbour() const { return mSegmentNeighbour[0]; }
42 GPUd() int32_t NextSegmentNeighbour() const { return mSegmentNeighbour[1]; }
43 GPUd() int32_t SegmentNeighbour(int32_t i) const { return mSegmentNeighbour[i]; }
44 GPUd() int32_t AnyNeighbour(int32_t i) const
45 {
46 return (i < 2) ? mSegmentNeighbour[i] : mNeighbour[i - 2];
47 }
48 GPUd() const GPUTPCTrack* OrigTrack() const { return mOrigTrack; }
49 GPUd() float X() const { return mParam.mX; }
50 GPUd() float Y() const { return mParam.mY; }
51 GPUd() float Z() const { return mParam.mZ; }
52 GPUd() float SinPhi() const { return mParam.mSinPhi; }
53 GPUd() float CosPhi() const { return mParam.mCosPhi; }
54 GPUd() float SecPhi() const { return mParam.mSecPhi; }
55 GPUd() float DzDs() const { return mParam.mDzDs; }
56 GPUd() float QPt() const { return mParam.mQPt; }
57 GPUd() float TZOffset() const { return mTZOffset; }
58 GPUd() uint8_t Leg() const { return mLeg; }
59
60 GPUd() int32_t LocalTrackId() const { return mLocalTrackId; }
61 GPUd() void SetLocalTrackId(int32_t v) { mLocalTrackId = v; }
62 GPUd() int32_t ExtrapolatedTrackId(int32_t n) const { return mExtrapolatedTrackIds[n]; }
63 GPUd() void SetExtrapolatedTrackId(int32_t n, int32_t v) { mExtrapolatedTrackIds[n] = v; }
64 GPUd() int32_t* ExtrapolatedTrackIds() { return mExtrapolatedTrackIds; }
65
66 GPUd() float MaxClusterZT() const { return CAMath::Max(mClusterZT[0], mClusterZT[1]); }
67 GPUd() float MinClusterZT() const { return CAMath::Min(mClusterZT[0], mClusterZT[1]); }
68 GPUd() float ClusterZT0() const { return mClusterZT[0]; }
69 GPUd() float ClusterZTN() const { return mClusterZT[1]; }
70 GPUd() void SetClusterZT(float v1, float v2)
71 {
72 mClusterZT[0] = v1;
74 }
75
77 GPUd() void SetParam2(const GPUTPCGMTrackParam& trk);
78 GPUd() void Set(const GPUTPCGMMerger* merger, const GPUTPCTrack* sectorTr, float alpha, int32_t sector);
79 GPUd() void UseParam2() { mParam = mParam2; }
80 GPUd() void SetX2(float v) { mParam2.mX = v; }
81 GPUd() float X2() const { return mParam2.mX; }
82
83 GPUd() void SetGlobalSectorTrackCov()
84 {
85 mParam.mC0 = 1;
86 mParam.mC2 = 1;
87 mParam.mC3 = 0;
88 mParam.mC5 = 1;
89 mParam.mC7 = 0;
90 mParam.mC9 = 1;
91 mParam.mC10 = 0;
92 mParam.mC12 = 0;
93 mParam.mC14 = 10;
94 }
95
96 GPUd() void SetNClusters(int32_t v) { mNClusters = v; }
97 GPUd() void SetPrevNeighbour(int32_t v) { mNeighbour[0] = v; }
98 GPUd() void SetNextNeighbour(int32_t v) { mNeighbour[1] = v; }
99 GPUd() void SetNeighbor(int32_t v, int32_t i) { mNeighbour[i] = v; }
100 GPUd() void SetPrevSegmentNeighbour(int32_t v) { mSegmentNeighbour[0] = v; }
101 GPUd() void SetNextSegmentNeighbour(int32_t v) { mSegmentNeighbour[1] = v; }
102 GPUd() void SetLeg(uint8_t v) { mLeg = v; }
103
104 GPUd() void CopyParamFrom(const GPUTPCGMSectorTrack& t)
105 {
106 mParam.mX = t.mParam.mX;
107 mParam.mY = t.mParam.mY;
108 mParam.mZ = t.mParam.mZ;
109 mParam.mSinPhi = t.mParam.mSinPhi;
110 mParam.mDzDs = t.mParam.mDzDs;
111 mParam.mQPt = t.mParam.mQPt;
112 mParam.mCosPhi = t.mParam.mCosPhi;
113 mParam.mSecPhi = t.mParam.mSecPhi;
114 mAlpha = t.mAlpha;
115 }
116
117 GPUd() bool FilterErrors(const GPUTPCGMMerger* merger, int32_t iSector, float maxSinPhi = GPUCA_MAX_SIN_PHI, float sinPhiMargin = 0.f);
118 GPUd() bool TransportToX(GPUTPCGMMerger* merger, float x, float Bz, GPUTPCGMBorderTrack& b, float maxSinPhi, bool doCov = true) const;
119 GPUd() bool TransportToXAlpha(GPUTPCGMMerger* merger, float x, float sinAlpha, float cosAlpha, float Bz, GPUTPCGMBorderTrack& b, float maxSinPhi) const;
120 GPUd() void CopyBaseTrackCov();
122 float mX, mY, mZ, mSinPhi, mDzDs, mQPt, mCosPhi, mSecPhi; // parameters
123 float mC0, mC2, mC3, mC5, mC7, mC9, mC10, mC12, mC14; // covariances
124 };
125
126 private:
127 const GPUTPCTrack* mOrigTrack; // pointer to original sector track
128 sectorTrackParam mParam; // Track parameters
129 sectorTrackParam mParam2; // Parameters at other side
130 float mTZOffset; // Z offset with early transform, T offset otherwise
131 float mAlpha; // alpha angle
132 float mClusterZT[2]; // Minimum maximum cluster Z / T
133 int32_t mNClusters; // N clusters
134 int32_t mNeighbour[2]; //
135 int32_t mSegmentNeighbour[2]; //
136 int32_t mLocalTrackId; // Corrected local track id in terms of GMSectorTracks array for extrapolated tracks, UNDEFINED for local tracks!
137 int32_t mExtrapolatedTrackIds[2]; // IDs of associated extrapolated tracks
138 uint8_t mSector; // sector of this track segment
139 uint8_t mLeg; // Leg of this track segment
140
141 ClassDefNV(GPUTPCGMSectorTrack, 1);
142};
143} // namespace o2::gpu
144
145#endif
#define GPUCA_MAX_SIN_PHI
float float GPUTPCGMBorderTrack float bool doCov
GPUd() int32_t SegmentNeighbour(int32_t i) const
GPUd() int32_t NClusters() const
GPUd() void SetPrevNeighbour(int32_t v)
GPUd() float ClusterZTN() const
GPUd() int32_t NextSegmentNeighbour() const
GPUd() float MaxClusterZT() const
GPUd() int32_t PrevNeighbour() const
GPUd() int32_t *ExtrapolatedTrackIds()
GPUd() void SetExtrapolatedTrackId(int32_t n
GPUd() float ClusterZT0() const
GPUd() int32_t PrevSegmentNeighbour() const
GPUd() void SetLeg(uint8_t v)
GPUd() void SetNClusters(int32_t v)
GPUd() int32_t LocalTrackId() const
float float float float GPUTPCGMBorderTrack float maxSinPhi const
GPUd() float TZOffset() const
GPUd() bool FilterErrors(const GPUTPCGMMerger *merger
GPUd() int32_t AnyNeighbour(int32_t i) const
GPUd() void SetNeighbor(int32_t v
GPUd() int32_t Neighbour(int32_t i) const
GPUd() void SetNextNeighbour(int32_t v)
GPUd() void SetPrevSegmentNeighbour(int32_t v)
GPUd() const GPUTPCTrack *OrigTrack() const
const GPUTPCTrack float int32_t sector
GPUd() uint8_t Sector() const
GPUd() int32_t ExtrapolatedTrackId(int32_t n) const
GPUd() float MinClusterZT() const
GPUd() int32_t NextNeighbour() const
GPUd() void SetGlobalSectorTrackCov()
GPUd() void SetLocalTrackId(int32_t v)
GPUd() void SetClusterZT(float v1
GPUd() void SetNextSegmentNeighbour(int32_t v)
GPUd() void CopyParamFrom(const GPUTPCGMSectorTrack &t)
GLdouble n
Definition glcorearb.h:1982
GLfloat GLfloat GLfloat alpha
Definition glcorearb.h:279
GLint GLenum GLint x
Definition glcorearb.h:403
const GLdouble * v
Definition glcorearb.h:832
GLdouble f
Definition glcorearb.h:310
GLboolean GLboolean GLboolean b
Definition glcorearb.h:1233
typedef void(APIENTRYP PFNGLCULLFACEPROC)(GLenum mode)
GLfloat GLfloat v1
Definition glcorearb.h:812
GLfloat GLfloat GLfloat v2
Definition glcorearb.h:813