spdlog/bench/padder_bench.cpp

59 lines
1.8 KiB
C++
Raw Normal View History

2018-11-11 06:52:21 +08:00
//
// Copyright(c) 2018 Gabi Melman.
// Distributed under the MIT License (http://opensource.org/licenses/MIT)
//
//
// latency.cpp : spdlog latency benchmarks
//
#include "benchmark/benchmark.h"
#include "spdlog/spdlog.h"
#include "spdlog/details/pattern_formatter.h"
void bench_scoped_pad(benchmark::State &state, size_t wrapped_size, spdlog::details::padding_info padinfo)
{
fmt::memory_buffer dest;
for (auto _ : state)
{
{
spdlog::details::scoped_pad p(wrapped_size, padinfo, dest);
benchmark::DoNotOptimize(p);
}
2018-11-11 07:26:57 +08:00
// if(dest.size() != (padinfo.width_-wrapped_size))
// {
// printf("NOT GOOD wrapped_size=%zu\t padinfo.width= %zu\tdest = %zu\n", wrapped_size, padinfo.width_, dest.size());
// }
2018-11-11 06:52:21 +08:00
dest.clear();
}
}
2018-11-11 07:26:57 +08:00
int main(int argc, char *argv[])
{
2018-11-11 06:52:21 +08:00
using spdlog::details::padding_info;
spdlog::set_pattern("[tid %t] %v");
std::vector<size_t> sizes = {0, 2, 4, 8, 16, 32, 64, 128};
2018-11-11 07:26:57 +08:00
for (auto size : sizes)
2018-11-11 06:52:21 +08:00
{
size_t wrapped_size = 8;
size_t padding_size = wrapped_size + size;
std::string title = "scoped_pad::left::" + std::to_string(size);
2018-11-11 07:26:57 +08:00
benchmark::RegisterBenchmark(title.c_str(), bench_scoped_pad, wrapped_size, padding_info(padding_size, padding_info::left));
2018-11-11 06:52:21 +08:00
title = "scoped_pad::right::" + std::to_string(size);
2018-11-11 07:26:57 +08:00
benchmark::RegisterBenchmark(title.c_str(), bench_scoped_pad, wrapped_size, padding_info(padding_size, padding_info::right));
2018-11-11 06:52:21 +08:00
title = "scoped_pad::center::" + std::to_string(size);
2018-11-11 07:26:57 +08:00
benchmark::RegisterBenchmark(title.c_str(), bench_scoped_pad, wrapped_size, padding_info(padding_size, padding_info::center));
2018-11-11 06:52:21 +08:00
}
benchmark::Initialize(&argc, argv);
benchmark::RunSpecifiedBenchmarks();
}