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