51 using LogFunc = std::function<
void(
const std::string& s)>;
59 const LogFunc& = [](
const std::string& s) { std::cout << s <<
'\n'; },
60 const LogFunc& = [](
const std::string& s) { std::cerr << s <<
'\n'; });
62 void setParameters(
const std::vector<TrackingParameters>& p) { mTrkParams = p; }
63 void setMemoryPool(std::shared_ptr<BoundedMemoryResource> pool) { mMemoryPool = pool; }
65 void setBz(
float bz) { mTraits->setBz(bz); }
67 void setNThreads(
int n, std::shared_ptr<tbb::task_arena>& arena) { mTraits->setNThreads(
n, arena); }
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); }
78 void rectifyClusterIndices();
81 template <
typename...
T,
typename... F>
82 float evaluateTask(
void (Tracker::*task)(
T...),
std::string_view taskName,
int iteration, const LogFunc& logger, F&&... args);
84 TrackerTraits<NLayers>* mTraits =
nullptr;
85 TimeFrame<NLayers>* mTimeFrame =
nullptr;
87 std::vector<TrackingParameters> mTrkParams;
91 unsigned int mNumberOfDroppedTFs{0};
92 unsigned int mTimeFrameCounter{0};
94 std::shared_ptr<BoundedMemoryResource> mMemoryPool;
105 Steps mCurStep{TFInit};
106 static constexpr std::array<const char*, NSteps> StateNames{
"TimeFrame initialisation",
"Tracklet finding",
"Cell finding",
"Neighbour finding",
"Road finding",
"Track extending"};
107 std::vector<std::array<TimingStats, NSteps>> mTimingStats;
108 void addTimingStatCurStep(
int iteration,
double timeMs);
117 if (mTrkParams[iteration].PrintMemory) {
118 mMemoryPool->resetPeakMemory();
122 auto start = std::chrono::high_resolution_clock::now();
123 (this->*task)(std::forward<F>(args)...);
124 auto end = std::chrono::high_resolution_clock::now();
126 std::chrono::duration<double, std::milli> diff_t{
end -
start};
127 diff = diff_t.count();
129 std::stringstream sstream;
130 if (taskName.empty()) {
131 sstream << diff <<
"\t";
133 sstream << std::setw(2) <<
" - " << taskName <<
" completed in: " << diff <<
" ms";
135 logger(sstream.str());
137 if (mTrkParams[iteration].SaveTimeBenchmarks) {
138 std::string taskNameStr(taskName);
139 std::transform(taskNameStr.begin(), taskNameStr.end(), taskNameStr.begin(),
140 [](
unsigned char c) { return std::tolower(c); });
141 std::replace(taskNameStr.begin(), taskNameStr.end(),
' ',
'_');
142 if (std::ofstream file{
"its_time_benchmarks.txt", std::ios::app}) {
143 file <<
"trk:" << iteration <<
'\t' << taskNameStr <<
'\t' << diff <<
'\n';
145 addTimingStatCurStep(iteration, diff);
149 (this->*task)(std::forward<F>(args)...);
152 if (mTrkParams[iteration].PrintMemory) {
153 LOGP(info,
"iter:{}:{}: {}", iteration, StateNames[mCurStep], mMemoryPool->asString());