mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-25 14:25:01 +00:00
Require a steady clock for bench with at least micro precision
This commit is contained in:
parent
9e9e31aa10
commit
620bae34cf
@ -23,6 +23,9 @@ void
|
|||||||
benchmark::BenchRunner::RunAll(benchmark::duration elapsedTimeForOne)
|
benchmark::BenchRunner::RunAll(benchmark::duration elapsedTimeForOne)
|
||||||
{
|
{
|
||||||
perf_init();
|
perf_init();
|
||||||
|
if (std::ratio_less_equal<benchmark::clock::period, std::micro>::value) {
|
||||||
|
std::cerr << "WARNING: Clock precision is worse than microsecond - benchmarks may be less accurate!\n";
|
||||||
|
}
|
||||||
std::cout << "#Benchmark" << "," << "count" << "," << "min(ns)" << "," << "max(ns)" << "," << "average(ns)" << ","
|
std::cout << "#Benchmark" << "," << "count" << "," << "min(ns)" << "," << "max(ns)" << "," << "average(ns)" << ","
|
||||||
<< "min_cycles" << "," << "max_cycles" << "," << "average_cycles" << "\n";
|
<< "min_cycles" << "," << "max_cycles" << "," << "average_cycles" << "\n";
|
||||||
|
|
||||||
|
@ -37,13 +37,11 @@ BENCHMARK(CODE_TO_TIME);
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
namespace benchmark {
|
namespace benchmark {
|
||||||
// On many systems, the high_resolution_clock offers no better resolution than the steady_clock.
|
// In case high_resolution_clock is steady, prefer that, otherwise use steady_clock.
|
||||||
// If that's the case, prefer the steady_clock.
|
|
||||||
struct best_clock {
|
struct best_clock {
|
||||||
using hi_res_clock = std::chrono::high_resolution_clock;
|
using hi_res_clock = std::chrono::high_resolution_clock;
|
||||||
using steady_clock = std::chrono::steady_clock;
|
using steady_clock = std::chrono::steady_clock;
|
||||||
static constexpr bool steady_is_high_res = std::ratio_less_equal<steady_clock::period, hi_res_clock::period>::value;
|
using type = std::conditional<hi_res_clock::is_steady, hi_res_clock, steady_clock>::type;
|
||||||
using type = std::conditional<steady_is_high_res, steady_clock, hi_res_clock>::type;
|
|
||||||
};
|
};
|
||||||
using clock = best_clock::type;
|
using clock = best_clock::type;
|
||||||
using time_point = clock::time_point;
|
using time_point = clock::time_point;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user