Project
Loading...
Searching...
No Matches
GPUTrackingRefit.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
14
15#define GPUCA_CADEBUG 0
16
17#include "GPUTrackingRefit.h"
18#include "GPUO2DataTypes.h"
19#include "GPUTPCGMTrackParam.h"
20#include "GPUTPCGMMergedTrack.h"
21#include "GPUTPCGMPropagator.h"
22#include "GPUConstantMem.h"
27#include "GPUParam.inc"
28#include "GPUCommonArray.h"
29#include "GPUParam.h"
31#include "GPUCommonTypeTraits.h"
32
33using namespace o2::gpu;
34using namespace o2::track;
35using namespace o2::base;
36using namespace o2::tpc;
37
38static constexpr int32_t kIGNORE_ENDS = 3;
39
40#define IgnoreErrors(SNP) \
41 if (mIgnoreErrorsOnTrackEnds) { \
42 if (abs(i - stop) <= kIGNORE_ENDS && (CAMath::Abs(SNP) >= Propagator::MAX_SIN_PHI || abs(start - stop) < 30)) { \
43 break; \
44 } \
45 if (abs(i - start) <= kIGNORE_ENDS && (CAMath::Abs(SNP) >= Propagator::MAX_SIN_PHI || abs(start - stop) < 30)) { \
46 continue; \
47 } \
48 }
49// End IgnoreErrors
50
51#ifndef GPUCA_GPUCODE
55
60
64#endif
65
66namespace o2::gpu::internal
67{
68namespace // anonymous
69{
70template <class T>
71struct refitTrackTypes;
72template <>
73struct refitTrackTypes<GPUTPCGMTrackParam> {
74 using propagator = GPUTPCGMPropagator;
75};
76template <>
77struct refitTrackTypes<TrackParCov> {
78 using propagator = const Propagator*;
79};
80} // anonymous namespace
81} // namespace o2::gpu::internal
82
83template <>
84GPUd() void GPUTrackingRefit::initProp<GPUgeneric() GPUTPCGMPropagator>(GPUTPCGMPropagator& prop) // FIXME: GPUgeneric() needed to make the clang spirv output link correctly
85{
86 prop.SetMaterialTPC();
87 prop.SetMaxSinPhi(GPUCA_MAX_SIN_PHI);
88 prop.SetToyMCEventsFlag(false);
89 prop.SetSeedingErrors(false);
90 prop.SetFitInProjections(mPparam->rec.fitInProjections != 0);
91 prop.SetPropagateBzOnly(false);
92 prop.SetPolynomialField(&mPparam->polynomialField);
93 prop.SetMatLUT(mPmatLUT);
94}
95
96template <>
97GPUd() void GPUTrackingRefit::initProp<const Propagator * GPUgeneric()>(const Propagator*& prop) // FIXME: GPUgeneric() needed to make the clang spirv output link correctly
98{
99 prop = mPpropagator;
100}
101
102template <class T, class S, class U>
103GPUd() void GPUTrackingRefit::convertTrack(T& trk, const S& trkX, U& prop, float* chi2)
104{
105 trk = trkX;
106}
107
108// Generic
109template <>
111{
112 convertTrackParam(trk, trkX);
113 prop.SetTrack(&trk, trkX.getAlpha());
114}
115template <>
117{
118 convertTrackParam(trk, trkX);
119 trk.setAlpha(prop.GetAlpha());
120}
121// GPUTPCGMMergedTrack input
122template <>
123GPUd() void GPUTrackingRefit::convertTrack<TrackParCov, GPUTPCGMMergedTrack, const Propagator*>(TrackParCov& trk, const GPUTPCGMMergedTrack& trkX, const Propagator*& prop, float* chi2)
124{
125 initProp(prop);
126 convertTrackParam(trk, trkX.GetParam());
127 trk.setAlpha(trkX.GetAlpha());
128 *chi2 = trkX.GetParam().GetChi2();
129}
130template <>
131GPUd() void GPUTrackingRefit::convertTrack<GPUTPCGMMergedTrack, TrackParCov, const Propagator*>(GPUTPCGMMergedTrack& trk, const TrackParCov& trkX, const Propagator*& prop, float* chi2)
132{
133 convertTrackParam(trk.Param(), trkX);
134 trk.SetAlpha(trkX.getAlpha());
135 trk.Param().SetChi2(*chi2);
136}
137template <>
139{
140 initProp(prop);
141 trk = trkX.GetParam();
142 prop.SetTrack(&trk, trkX.GetAlpha());
143}
144template <>
146{
147 trk.SetParam(trkX);
148 trk.SetAlpha(prop.GetAlpha());
149}
150// TrackTPC input
151template <>
152GPUd() void GPUTrackingRefit::convertTrack<TrackParCov, TrackTPC, const Propagator*>(TrackParCov& trk, const TrackTPC& trkX, const Propagator*& prop, float* chi2)
153{
154 initProp(prop);
155 convertTrack<TrackParCov, TrackParCov, const Propagator*>(trk, trkX, prop, nullptr);
156 *chi2 = trkX.getChi2();
157}
158template <>
159GPUd() void GPUTrackingRefit::convertTrack<TrackTPC, TrackParCov, const Propagator*>(TrackTPC& trk, const TrackParCov& trkX, const Propagator*& prop, float* chi2)
160{
161 convertTrack<TrackParCov, TrackParCov, const Propagator*>(trk, trkX, prop, nullptr);
162 trk.setChi2(*chi2);
163}
164template <>
166{
167 initProp(prop);
168 convertTrack<GPUTPCGMTrackParam, TrackParCov, GPUTPCGMPropagator>(trk, trkX, prop, nullptr);
169 trk.SetChi2(trkX.getChi2());
170}
171template <>
173{
174 convertTrack<TrackParCov, GPUTPCGMTrackParam, GPUTPCGMPropagator>(trk, trkX, prop, nullptr);
175 trk.setChi2(trkX.GetChi2());
176}
177// TrackParCovWithArgs input
178template <>
179GPUd() void GPUTrackingRefit::convertTrack<TrackParCov, GPUTrackingRefit::TrackParCovWithArgs, const Propagator*>(TrackParCov& trk, const GPUTrackingRefit::TrackParCovWithArgs& trkX, const Propagator*& prop, float* chi2)
180{
181 initProp(prop);
182 convertTrack<TrackParCov, TrackParCov, const Propagator*>(trk, trkX.trk, prop, nullptr);
183 *chi2 = trkX.chi2 ? *trkX.chi2 : 0.f;
184}
185template <>
186GPUd() void GPUTrackingRefit::convertTrack<GPUTrackingRefit::TrackParCovWithArgs, TrackParCov, const Propagator*>(GPUTrackingRefit::TrackParCovWithArgs& trk, const TrackParCov& trkX, const Propagator*& prop, float* chi2)
187{
188 convertTrack<TrackParCov, TrackParCov, const Propagator*>(trk.trk, trkX, prop, nullptr);
189 if (trk.chi2) {
190 *trk.chi2 = *chi2;
191 }
192}
193template <>
194GPUd() void GPUTrackingRefit::convertTrack<GPUTPCGMTrackParam, GPUTrackingRefit::TrackParCovWithArgs, GPUTPCGMPropagator>(GPUTPCGMTrackParam& trk, const GPUTrackingRefit::TrackParCovWithArgs& trkX, GPUTPCGMPropagator& prop, float* chi2)
195{
196 initProp(prop);
197 convertTrack<GPUTPCGMTrackParam, TrackParCov, GPUTPCGMPropagator>(trk, trkX.trk, prop, nullptr);
198 trk.SetChi2(trkX.chi2 ? *trkX.chi2 : 0.f);
199}
200template <>
201GPUd() void GPUTrackingRefit::convertTrack<GPUTrackingRefit::TrackParCovWithArgs, GPUTPCGMTrackParam, GPUTPCGMPropagator>(GPUTrackingRefit::TrackParCovWithArgs& trk, const GPUTPCGMTrackParam& trkX, GPUTPCGMPropagator& prop, float* chi2)
202{
203 convertTrack<TrackParCov, GPUTPCGMTrackParam, GPUTPCGMPropagator>(trk.trk, trkX, prop, chi2);
204 if (trk.chi2) {
205 *trk.chi2 = trkX.GetChi2();
206 }
207}
208
209GPUd() static const float* getPar(const GPUTPCGMTrackParam& trk) { return trk.GetPar(); }
210GPUd() static const float* getPar(const TrackParCov& trk) { return trk.getParams(); }
211
212template <class T, class S>
213GPUd() int32_t GPUTrackingRefit::RefitTrack(T& trkX, bool outward, bool resetCov)
214{
215 CADEBUG(int32_t ii; printf("\nRefitting track\n"));
216 typename internal::refitTrackTypes<S>::propagator prop;
217 S trk;
218 float TrackParCovChi2 = 0.f;
219 convertTrack<S, T, typename internal::refitTrackTypes<S>::propagator>(trk, trkX, prop, &TrackParCovChi2);
220 int32_t begin = 0, count;
221 float tOffset;
222 if constexpr (std::is_same_v<T, GPUTPCGMMergedTrack>) {
223 count = trkX.NClusters();
224 if (trkX.Looper()) {
225 int32_t leg = mPtrackHits[trkX.FirstClusterRef() + trkX.NClusters() - 1].leg;
226 for (int32_t i = trkX.NClusters() - 2; i > 0; i--) {
227 if (mPtrackHits[trkX.FirstClusterRef() + i].leg != leg) {
228 begin = i + 1;
229 break;
230 }
231 }
232 }
233 tOffset = trkX.GetParam().GetTZOffset();
234 } else if constexpr (std::is_same_v<T, TrackTPC>) {
235 count = trkX.getNClusters();
236 tOffset = trkX.getTime0();
237 } else if constexpr (std::is_same_v<T, TrackParCovWithArgs>) {
238 count = trkX.clusRef.getEntries();
239 tOffset = trkX.time0;
240 } else {
241 static_assert("Invalid template");
242 }
243 if constexpr (std::is_same_v<S, GPUTPCGMTrackParam>) {
244 CADEBUG(printf("\t%21sInit Alpha %8.3f , X %8.3f - Y %8.3f, Z %8.3f - QPt %7.2f (%7.2f), SP %5.2f (%5.2f) --- Cov sY %8.3f sZ %8.3f sSP %8.3f sPt %8.3f\n", "", prop.GetAlpha(), trk.GetX(), trk.Par()[0], trk.Par()[1], trk.Par()[4], prop.GetQPt0(), trk.Par()[2], prop.GetSinPhi0(), sqrtf(trk.Cov()[0]), sqrtf(trk.Cov()[2]), sqrtf(trk.Cov()[5]), sqrtf(trk.Cov()[14])));
245 }
246
247 int32_t direction = outward ? -1 : 1;
248 int32_t start = outward ? count - 1 : begin;
249 int32_t stop = outward ? begin - 1 : count;
250 const ClusterNative* cl = nullptr;
251 uint8_t sector = 255, row = 255;
252 int32_t lastSector = -1, currentSector = -1, currentRow = -1;
253 int16_t clusterState = 0, nextState = 0;
254 int32_t nFitted = 0;
255 float sumInvSqrtCharge = 0.f;
256 int32_t nAvgCharge = 0;
257
258 for (int32_t i = start; i != stop; i += cl ? 0 : direction) {
259 float x = 0, y = 0, z = 0, charge = 0; // FIXME: initialization unneeded, but GCC incorrectly produces uninitialized warnings otherwise
260 float time = 0.f, invCharge = 0.f, invSqrtCharge = 0.f; // Same here...
261 int32_t clusters = 0;
262 while (true) {
263 if (!cl) {
264 CADEBUG(ii = i);
265 if constexpr (std::is_same_v<T, GPUTPCGMMergedTrack>) {
266 const auto& hit = mPtrackHits[trkX.FirstClusterRef() + i];
267 cl = &mPclusterNative->clustersLinear[hit.num];
269 cl = nullptr;
270 if (i + direction != stop) {
271 i += direction;
272 continue;
273 }
274 break;
275 }
276 row = hit.row;
277 sector = hit.sector;
278 nextState = mPclusterState[hit.num];
279 } else if constexpr (std::is_same_v<T, TrackTPC>) {
280 cl = &trkX.getCluster(mPtrackHitReferences, i, *mPclusterNative, sector, row);
281 nextState = mPclusterState[cl - mPclusterNative->clustersLinear];
282 } else if constexpr (std::is_same_v<T, TrackParCovWithArgs>) {
283 cl = &TrackTPC::getCluster(mPtrackHitReferences, i, *mPclusterNative, sector, row, trkX.clusRef);
284 nextState = mPclusterState[cl - mPclusterNative->clustersLinear];
285 } else {
286 static_assert("Invalid template");
287 }
288 }
289 if (clusters == 0 || (row == currentRow && sector == currentSector)) {
290 if (clusters == 1) {
291 x *= charge;
292 y *= charge;
293 z *= charge;
294 }
295 if (clusters == 0) {
296 mPfastTransformHelper->Transform(sector, row, cl->getPad(), cl->getTime(), x, y, z, tOffset);
297 CADEBUG(printf("\tHit %3d/%3d Row %3d: Cluster Alpha %8.3f %3d, X %8.3f - Y %8.3f, Z %8.3f - State %d\n", ii, count, row, mPparam->Alpha(sector), (int32_t)sector, x, y, z, (int32_t)nextState));
298 currentRow = row;
299 currentSector = sector;
300 charge = cl->qTot;
301 clusterState = nextState;
302 time = cl->getTime();
303 invSqrtCharge = CAMath::InvSqrt(cl->qMax);
304 invCharge = (1.f / cl->qMax);
305 } else {
306 float xx, yy, zz;
307 mPfastTransformHelper->Transform(sector, row, cl->getPad(), cl->getTime(), xx, yy, zz, tOffset);
308 CADEBUG(printf("\tHit %3d/%3d Row %3d: Cluster Alpha %8.3f %3d, X %8.3f - Y %8.3f, Z %8.3f - State %d\n", ii, count, row, mPparam->Alpha(sector), (int32_t)sector, xx, yy, zz, (int32_t)nextState));
309 x += xx * cl->qTot;
310 y += yy * cl->qTot;
311 z += zz * cl->qTot;
312 charge += cl->qTot;
313 clusterState |= nextState;
314 }
315 cl = nullptr;
316 clusters++;
317 if (i + direction != stop) {
318 i += direction;
319 continue;
320 }
321 }
322 break;
323 }
324 if (clusters == 0) {
325 continue;
326 } else if (clusters > 1) {
327 x /= charge;
328 y /= charge;
329 z /= charge;
330 CADEBUG(printf("\tMerged Hit Row %3d: Cluster Alpha %8.3f %3d, X %8.3f - Y %8.3f, Z %8.3f - State %d\n", row, mPparam->Alpha(sector), (int32_t)sector, x, y, z, (int32_t)clusterState));
331 }
332
333 float invAvgCharge = (sumInvSqrtCharge += invSqrtCharge) / ++nAvgCharge;
334 invAvgCharge *= invAvgCharge;
335
336 if constexpr (std::is_same_v<S, GPUTPCGMTrackParam>) {
337 if (prop.PropagateToXAlpha(x, mPparam->Alpha(currentSector), !outward)) {
338 IgnoreErrors(trk.GetSinPhi());
339 return -2;
340 }
341 if (resetCov) {
342 trk.ResetCovariance();
343 } else if (lastSector != -1 && (lastSector < 18) != (sector < 18)) {
344 if (mPparam->rec.tpc.addErrorsCECrossing) {
345 if (mPparam->rec.tpc.addErrorsCECrossing >= 2) {
346 trk.AddCovDiagErrorsWithCorrelations(mPparam->rec.tpc.errorsCECrossing);
347 } else {
348 trk.AddCovDiagErrors(mPparam->rec.tpc.errorsCECrossing);
349 }
350 } else if (trk.Cov()[2] < 0.5f) {
351 trk.Cov()[2] = 0.5f;
352 }
353 }
354 CADEBUG(printf("\t%21sPropaga Alpha %8.3f , X %8.3f - Y %8.3f, Z %8.3f - QPt %7.2f (%7.2f), SP %5.2f (%5.2f) --- Res %8.3f %8.3f --- Cov sY %8.3f sZ %8.3f sSP %8.3f sPt %8.3f - YPt %8.3f\n", "", prop.GetAlpha(), x, trk.Par()[0], trk.Par()[1], trk.Par()[4], prop.GetQPt0(), trk.Par()[2], prop.GetSinPhi0(), trk.Par()[0] - y, trk.Par()[1] - z, sqrtf(trk.Cov()[0]), sqrtf(trk.Cov()[2]), sqrtf(trk.Cov()[5]), sqrtf(trk.Cov()[14]), trk.Cov()[10]));
355 lastSector = sector;
356 if (prop.Update(y, z, row, *mPparam, clusterState, 0, nullptr, true, sector, time, invAvgCharge, invCharge)) {
357 IgnoreErrors(trk.GetSinPhi());
358 return -3;
359 }
360 trk.ConstrainSinPhi();
361 CADEBUG(printf("\t%21sFit Alpha %8.3f , X %8.3f - Y %8.3f, Z %8.3f - QPt %7.2f (%7.2f), SP %5.2f (%5.2f), DzDs %5.2f %16s --- Cov sY %8.3f sZ %8.3f sSP %8.3f sPt %8.3f - YPt %8.3f\n", "", prop.GetAlpha(), x, trk.Par()[0], trk.Par()[1], trk.Par()[4], prop.GetQPt0(), trk.Par()[2], prop.GetSinPhi0(), trk.Par()[3], "", sqrtf(trk.Cov()[0]), sqrtf(trk.Cov()[2]), sqrtf(trk.Cov()[5]), sqrtf(trk.Cov()[14]), trk.Cov()[10]));
362 } else if constexpr (std::is_same_v<S, TrackParCov>) {
363 if (!trk.rotate(mPparam->Alpha(currentSector))) {
364 IgnoreErrors(trk.getSnp());
365 return -1;
366 }
367 if (!prop->PropagateToXBxByBz(trk, x, GPUCA_MAX_SIN_PHI_LOW)) {
368 IgnoreErrors(trk.getSnp());
369 return -2;
370 }
371 if (lastSector != -1 && (lastSector < 18) != (sector < 18)) {
372 if (mPparam->rec.tpc.addErrorsCECrossing) {
373 trk.updateCov(mPparam->rec.tpc.errorsCECrossing, mPparam->rec.tpc.addErrorsCECrossing >= 2);
374 } else if (trk.getCov()[2] < 0.5f) {
375 trk.setCov(0.5f, 2);
376 }
377 }
378 if (resetCov) {
379 trk.resetCovariance();
380 float bzkG = prop->getNominalBz(), qptB5Scale = CAMath::Abs(bzkG) > 0.1f ? CAMath::Abs(bzkG) / 5.006680f : 1.f;
381 float q2pt2 = trk.getQ2Pt() * trk.getQ2Pt(), q2pt2Wgh = q2pt2 * qptB5Scale * qptB5Scale;
382 float err2 = (100.f + q2pt2Wgh) / (1.f + q2pt2Wgh) * q2pt2; // -> 100 for high pTs, -> 1 for low pTs.
383 trk.setCov(err2, 14); // 100% error
384 TrackParCovChi2 = 0.f;
385 }
386 CADEBUG(printf("\t%21sPropaga Alpha %8.3f , X %8.3f - Y %8.3f, Z %8.3f - QPt %7.2f (%7.2f), SP %5.2f (%5.2f) --- Res %8.3f %8.3f --- Cov sY %8.3f sZ %8.3f sSP %8.3f sPt %8.3f - YPt %8.3f\n", "", trk.getAlpha(), x, trk.getParams()[0], trk.getParams()[1], trk.getParams()[4], trk.getParams()[4], trk.getParams()[2], trk.getParams()[2], trk.getParams()[0] - y, trk.getParams()[1] - z, sqrtf(trk.getCov()[0]), sqrtf(trk.getCov()[2]), sqrtf(trk.getCov()[5]), sqrtf(trk.getCov()[14]), trk.getCov()[10]));
389 GPUTPCGMPropagator::GetErr2(c[0], c[2], *mPparam, getPar(trk)[2], getPar(trk)[3], z, x, y, currentRow, clusterState, sector, time, invAvgCharge, invCharge, false);
390 TrackParCovChi2 += trk.getPredictedChi2(p, c);
391 if (!trk.update(p, c)) {
392 IgnoreErrors(trk.getSnp());
393 return -3;
394 }
395 CADEBUG(printf("\t%21sFit Alpha %8.3f , X %8.3f - Y %8.3f, Z %8.3f - QPt %7.2f (%7.2f), SP %5.2f (%5.2f), DzDs %5.2f %16s --- Cov sY %8.3f sZ %8.3f sSP %8.3f sPt %8.3f - YPt %8.3f\n", "", trk.getAlpha(), x, trk.getParams()[0], trk.getParams()[1], trk.getParams()[4], trk.getParams()[4], trk.getParams()[2], trk.getParams()[2], trk.getParams()[3], "", sqrtf(trk.getCov()[0]), sqrtf(trk.getCov()[2]), sqrtf(trk.getCov()[5]), sqrtf(trk.getCov()[14]), trk.getCov()[10]));
396 } else {
397 static_assert("Invalid template");
398 }
399 resetCov = false;
400 nFitted++;
401 }
402 if constexpr (std::is_same_v<S, GPUTPCGMTrackParam>) {
403 float alpha = prop.GetAlpha();
404 trk.MoveToReference(prop, *mPparam, alpha);
405 trk.NormalizeAlpha(alpha);
406 prop.SetAlpha(alpha);
407 } else if constexpr (std::is_same_v<S, TrackParCov>) {
408 static constexpr float kDeg2Rad = M_PI / 180.f;
409 static constexpr float kSectAngle = 2 * M_PI / 18.f;
410 if (mPparam->rec.tpc.trackReferenceX <= 500) {
411 if (prop->PropagateToXBxByBz(trk, mPparam->rec.tpc.trackReferenceX)) {
412 if (CAMath::Abs(trk.getY()) > trk.getX() * CAMath::Tan(kSectAngle / 2.f)) {
413 float newAlpha = trk.getAlpha() + CAMath::Round(CAMath::ATan2(trk.getY(), trk.getX()) / kDeg2Rad / 20.f) * kSectAngle;
414 GPUTPCGMTrackParam::NormalizeAlpha(newAlpha);
415 trk.rotate(newAlpha) && prop->PropagateToXBxByBz(trk, mPparam->rec.tpc.trackReferenceX);
416 }
417 }
418 }
419 } else {
420 static_assert("Invalid template");
421 }
422
423 convertTrack<T, S, typename internal::refitTrackTypes<S>::propagator>(trkX, trk, prop, &TrackParCovChi2);
424 return nFitted;
425}
426
427#if !defined(GPUCA_GPUCODE) || defined(GPUCA_GPUCODE_DEVICE) // FIXME: DR: WORKAROUND to avoid CUDA bug creating host symbols for device code.
428template GPUdni() int32_t GPUTrackingRefit::RefitTrack<GPUTPCGMMergedTrack, TrackParCov>(GPUTPCGMMergedTrack& trk, bool outward, bool resetCov);
429template GPUdni() int32_t GPUTrackingRefit::RefitTrack<GPUTPCGMMergedTrack, GPUTPCGMTrackParam>(GPUTPCGMMergedTrack& trk, bool outward, bool resetCov);
430template GPUdni() int32_t GPUTrackingRefit::RefitTrack<TrackTPC, TrackParCov>(TrackTPC& trk, bool outward, bool resetCov);
431template GPUdni() int32_t GPUTrackingRefit::RefitTrack<TrackTPC, GPUTPCGMTrackParam>(TrackTPC& trk, bool outward, bool resetCov);
432template GPUdni() int32_t GPUTrackingRefit::RefitTrack<GPUTrackingRefit::TrackParCovWithArgs, TrackParCov>(GPUTrackingRefit::TrackParCovWithArgs& trk, bool outward, bool resetCov);
433template GPUdni() int32_t GPUTrackingRefit::RefitTrack<GPUTrackingRefit::TrackParCovWithArgs, GPUTPCGMTrackParam>(GPUTrackingRefit::TrackParCovWithArgs& trk, bool outward, bool resetCov);
434#endif
435
436#ifndef GPUCA_GPUCODE
438{
439 mPclusterState = v->ioPtrs.mergedTrackHitStates;
440 mPclusterNative = v->ioPtrs.clustersNative;
441 mPtrackHits = v->ioPtrs.mergedTrackHits;
442 mPfastTransformHelper = v->calibObjects.fastTransformHelper;
443 mPmatLUT = v->calibObjects.matLUT;
444 mPparam = p ? p : &v->param;
445}
446#endif
Helper class to access correction maps.
Base track model for the Barrel, params only, w/o covariance.
int16_t charge
Definition RawEventData.h:5
int16_t time
Definition RawEventData.h:4
int32_t i
#define GPUdni()
#define GPUgeneric()
#define GPUCA_MAX_SIN_PHI_LOW
#define GPUCA_MAX_SIN_PHI
#define CADEBUG(...)
Definition GPUDef.h:85
uint8_t leg
#define IgnoreErrors(SNP)
uint32_t c
Definition RawData.h:2
void SetMaxData(const GPUTrackingInOutPointers &io)
void SetPtrsFromGPUConstantMem(const GPUConstantMem *v, GPUParam *p=nullptr)
GLfloat GLfloat GLfloat alpha
Definition glcorearb.h:279
GLint GLenum GLint x
Definition glcorearb.h:403
GLint GLsizei count
Definition glcorearb.h:399
const GLdouble * v
Definition glcorearb.h:832
GLint y
Definition glcorearb.h:270
typedef void(APIENTRYP PFNGLCULLFACEPROC)(GLenum mode)
GLuint start
Definition glcorearb.h:469
GLdouble GLdouble GLdouble z
Definition glcorearb.h:843
std::array< T, N > array
const o2::track::TrackParCov & trkX
GPUd() const expr uint32_t MultivariatePolynomialHelper< Dim
Global TPC definitions and constants.
Definition SimTraits.h:167
Enum< T >::Iterator begin(Enum< T >)
Definition Defs.h:173
TrackParCovF TrackParCov
Definition Track.h:33
std::vector< Cluster > clusters
std::vector< int > row