8 #include <boost/assert.hpp> 13 : m_Kernels(nullptr), m_RealScheduler(realScheduler)
19 m_RealScheduler.set_num_threads(numThreads);
24 return m_RealScheduler.num_threads();
29 WallClockTimer::clock::time_point startTime = WallClockTimer::clock::now();
30 m_RealScheduler.schedule(kernel, hints.split_dimension());
31 WallClockTimer::clock::time_point stopTime = WallClockTimer::clock::now();
33 const auto delta = std::chrono::duration<double, std::micro>(stopTime - startTime);
34 m_Kernels->emplace_back(kernel->name(), delta.count(), Measurement::Unit::TIME_US);
39 WallClockTimer::clock::time_point startTime = WallClockTimer::clock::now();
40 m_RealScheduler.run_tagged_workloads(workloads,
nullptr);
41 WallClockTimer::clock::time_point stopTime = WallClockTimer::clock::now();
43 const auto delta = std::chrono::duration<double, std::micro>(stopTime - startTime);
44 m_Kernels->emplace_back(std::string(
"Workload"), delta.count(), Measurement::Unit::TIME_US);
49 WallClockTimer::clock::time_point startTime = WallClockTimer::clock::now();
50 m_RealScheduler.run_tagged_workloads(workloads, tag);
51 WallClockTimer::clock::time_point stopTime = WallClockTimer::clock::now();
53 const auto delta = std::chrono::duration<double, std::micro>(stopTime - startTime);
54 m_Kernels->emplace_back(std::string(tag !=
nullptr ? tag :
"Unknown"), delta.count(), Measurement::Unit::TIME_US);
Copyright (c) 2020 ARM Limited.
unsigned int num_threads() const override
void schedule(arm_compute::ICPPKernel *kernel, const Hints &hints) override
void run_tagged_workloads(std::vector< Workload > &workloads, const char *tag) override
NeonInterceptorScheduler(arm_compute::IScheduler &realScheduler)
void set_num_threads(unsigned int numThreads) override
void run_workloads(std::vector< Workload > &workloads) override