#pragma once #include #include #include #include #include #include namespace utils { template inline std::string format(const T& value) { static std::locale loc(""); std::stringstream ss; ss.imbue(loc); ss << value; return ss.str(); } template<> inline std::string format(const double & value) { static std::locale loc(""); std::stringstream ss; ss.imbue(loc); ss << std::fixed << std::setprecision(1) << value; return ss.str(); } inline void bench(const std::string& fn_name, const std::chrono::milliseconds &duration, const std::function& fn) { using namespace std::chrono; typedef steady_clock the_clock; size_t counter = 0; seconds print_interval(1); auto start_time = the_clock::now(); auto lastPrintTime = start_time; while (true) { fn(); ++counter; auto now = the_clock::now(); if (now - start_time >= duration) break; if (now - lastPrintTime >= print_interval) { std::cout << fn_name << ": " << format(counter) << " per sec" << std::endl; counter = 0; lastPrintTime = the_clock::now(); } } } inline void bench(const std::string& fn_name, const std::function& fn) { using namespace std::chrono; auto start = steady_clock::now(); fn(); auto delta = steady_clock::now() - start; std::cout << fn_name << ": " << duration_cast(delta).count() << " ms" << std::endl; } }