Project
Loading...
Searching...
No Matches
Tracker.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.
15
16#ifndef TRACKINGITSU_INCLUDE_TRACKER_H_
17#define TRACKINGITSU_INCLUDE_TRACKER_H_
18
19#include <array>
20#include <chrono>
21#include <fstream>
22#include <iomanip>
23#include <iosfwd>
24#include <memory>
25#include <string_view>
26#include <utility>
27#include <sstream>
28#include <vector>
29
30#include <oneapi/tbb/task_arena.h>
31
37
38namespace o2
39{
40
41namespace gpu
42{
43class GPUChainITS;
44}
45namespace its
46{
47
48template <int NLayers>
50{
51 using LogFunc = std::function<void(const std::string& s)>;
52
53 public:
55
57
58 float clustersToTracks(
59 const LogFunc& = [](const std::string& s) { std::cout << s << '\n'; },
60 const LogFunc& = [](const std::string& s) { std::cerr << s << '\n'; });
61
62 void setParameters(const std::vector<TrackingParameters>& p) { mTrkParams = p; }
63 void setMemoryPool(std::shared_ptr<BoundedMemoryResource> pool) { mMemoryPool = pool; }
64 std::vector<TrackingParameters>& getParameters() { return mTrkParams; }
65 void setBz(float bz) { mTraits->setBz(bz); }
66 void setTimeSlice(size_t slice) noexcept { mTimeSlice = slice; }
67 void setNThreads(int n, std::shared_ptr<tbb::task_arena>& arena) { mTraits->setNThreads(n, arena); }
68 void printSummary() const;
70
71 private:
72 void initialiseTimeFrame(int iteration) { mTraits->initialiseTimeFrame(iteration); }
73 void computeTracklets(int iteration, int iVertex) { mTraits->computeLayerTracklets(iteration, iVertex); }
74 void computeCells(int iteration) { mTraits->computeLayerCells(iteration); }
75 void findCellsNeighbours(int iteration) { mTraits->findCellsNeighbours(iteration); }
76 void findRoads(int iteration) { mTraits->findRoads(iteration); }
77
78 void rectifyClusterIndices();
79 void sortTracks();
80
81 template <typename... T, typename... F>
82 float evaluateTask(void (Tracker::*task)(T...), std::string_view taskName, int iteration, const LogFunc& logger, F&&... args);
83
84 TrackerTraits<NLayers>* mTraits = nullptr;
85 TimeFrame<NLayers>* mTimeFrame = nullptr;
86
87 std::vector<TrackingParameters> mTrkParams;
88 o2::gpu::GPUChainITS* mRecoChain = nullptr;
89
90 size_t mTimeSlice{0}; // current timeslice
91 unsigned int mNumberOfDroppedTFs{0};
92 unsigned int mTimeFrameCounter{0};
93 double mTotalTime{0};
94 std::shared_ptr<BoundedMemoryResource> mMemoryPool;
95
96 enum Steps {
97 TFInit = 0,
98 Trackleting,
99 Celling,
100 Neighbouring,
101 Roading,
102 NSteps,
103 };
104 Steps mCurStep{TFInit};
105 static constexpr std::array<const char*, NSteps> StateNames{"TimeFrame initialisation", "Tracklet finding", "Cell finding", "Neighbour finding", "Road finding"};
106 std::vector<std::array<TimingStats, NSteps>> mTimingStats;
107 void addTimingStatCurStep(int iteration, double timeMs);
108};
109
110template <int NLayers>
111template <typename... T, typename... F>
112float Tracker<NLayers>::evaluateTask(void (Tracker<NLayers>::*task)(T...), std::string_view taskName, int iteration, const LogFunc& logger, F&&... args)
113{
114 float diff{0.f};
115
116 if constexpr (constants::DoTimeBenchmarks) {
117 auto start = std::chrono::high_resolution_clock::now();
118 (this->*task)(std::forward<F>(args)...);
119 auto end = std::chrono::high_resolution_clock::now();
120
121 std::chrono::duration<double, std::milli> diff_t{end - start};
122 diff = diff_t.count();
123
124 std::stringstream sstream;
125 if (taskName.empty()) {
126 sstream << diff << "\t";
127 } else {
128 sstream << std::setw(2) << " - " << taskName << " completed in: " << diff << " ms";
129 }
130 logger(sstream.str());
131
132 if (mTrkParams[iteration].SaveTimeBenchmarks) {
133 std::string taskNameStr(taskName);
134 std::transform(taskNameStr.begin(), taskNameStr.end(), taskNameStr.begin(),
135 [](unsigned char c) { return std::tolower(c); });
136 std::replace(taskNameStr.begin(), taskNameStr.end(), ' ', '_');
137 if (std::ofstream file{"its_time_benchmarks.txt", std::ios::app}) {
138 file << "trk:" << iteration << '\t' << taskNameStr << '\t' << diff << '\n';
139 }
140 addTimingStatCurStep(iteration, diff);
141 }
142
143 } else {
144 (this->*task)(std::forward<F>(args)...);
145 }
146
147 if (mTrkParams[iteration].PrintMemory) {
148 LOGP(info, "iter:{}:{}: {}", iteration, StateNames[mCurStep], mMemoryPool->asString());
149 }
150
151 return diff;
152}
153
154} // namespace its
155} // namespace o2
156
157#endif /* TRACKINGITSU_INCLUDE_TRACKER_H_ */
uint32_t c
Definition RawData.h:2
void setMemoryPool(std::shared_ptr< BoundedMemoryResource > pool)
Definition Tracker.h:63
void setParameters(const std::vector< TrackingParameters > &p)
Definition Tracker.h:62
void adoptTimeFrame(TimeFrame< NLayers > &tf)
Definition Tracker.cxx:226
void printSummary() const
Definition Tracker.cxx:245
void computeTracksMClabels()
Definition Tracker.cxx:122
void setNThreads(int n, std::shared_ptr< tbb::task_arena > &arena)
Definition Tracker.h:67
float clustersToTracks(const LogFunc &=[](const std::string &s) { std::cout<< s<< '\n';}, const LogFunc &=[](const std::string &s) { std::cerr<< s<< '\n';})
Definition Tracker.cxx:37
void setBz(float bz)
Definition Tracker.h:65
std::vector< TrackingParameters > & getParameters()
Definition Tracker.h:64
void setTimeSlice(size_t slice) noexcept
Definition Tracker.h:66
GLdouble n
Definition glcorearb.h:1982
GLuint GLuint end
Definition glcorearb.h:469
typedef void(APIENTRYP PFNGLCULLFACEPROC)(GLenum mode)
GLuint start
Definition glcorearb.h:469
constexpr bool DoTimeBenchmarks
Definition Constants.h:28
a couple of static helper functions to create timestamp values for CCDB queries or override obsolete ...
std::unique_ptr< GPUReconstructionTimeframe > tf