#include #include #include #include "benchmark/benchmark_api.h" #include "GenerateInput.hpp" constexpr std::size_t TestNumInputs = 1024; template void BM_Sort(benchmark::State& st, GenInputs gen) { using ValueType = typename decltype(gen(0))::value_type; const auto in = gen(st.range(0)); std::vector inputs[5]; auto reset_inputs = [&]() { for (auto& C : inputs) { C = in; benchmark::DoNotOptimize(C.data()); } }; reset_inputs(); while (st.KeepRunning()) { for (auto& I : inputs) { std::sort(I.data(), I.data() + I.size()); benchmark::DoNotOptimize(I.data()); } st.PauseTiming(); reset_inputs(); benchmark::ClobberMemory(); st.ResumeTiming(); } } BENCHMARK_CAPTURE(BM_Sort, random_uint32, getRandomIntegerInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, sorted_ascending_uint32, getSortedIntegerInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, sorted_descending_uint32, getReverseSortedIntegerInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, single_element_uint32, getDuplicateIntegerInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, pipe_organ_uint32, getPipeOrganIntegerInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, random_strings, getRandomStringInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, sorted_ascending_strings, getSortedStringInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, sorted_descending_strings, getReverseSortedStringInputs)->Arg(TestNumInputs); BENCHMARK_CAPTURE(BM_Sort, single_element_strings, getDuplicateStringInputs)->Arg(TestNumInputs); BENCHMARK_MAIN()