ITS GPU tracking
- General priorities:
- Providing GPU ITS tracking alongside TPC via gpu-reco-workflow in full system test: few changes in fst script, but it does not work yet, due to different gpu-wf configurations wrt to my custom script. Investigating.
- Focusing on porting all of what is possible on the device, extending the state of the art, and minimising computing on the host.
- Tracking fully ported on GPU.
- Moving vertexing routines to the externally managed memory system. -> WIP
- Currrently optimising the o2::its::timeframeGPU intialisation GPU transfers, trying to maximise data reuse & anticipating loads when it is possible.
- Optimizations:
- Asynchronous parallelisation in the tracklet finding, i.e. Multi-streaming for obvious parallelisations.
- intelligent scheduling and multi-streaming can happen right after.
- Kernel-level optimisations to be investigated.
TODO:
-
- Thrust allocator with external memory management -> possibly the most critical missing piece, to find a decent way of introducing it.
- Reproducer for HIP bug on multi-threaded track fitting: no follow-up yet.
- Fix possible execution issues and known discrepancies when using
gpu-reco-workflow
: no progress.
DCAFitterGPU
- Deterministic approach via using
SMatrixGPU
on the host, under particular configuration: no progress.