123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- #include <cstddef>
- #include <random>
- #include <vector>
- #include <benchmark/benchmark.h>
- #include <audio_utils/primitives.h>
- static void BM_MemcpyToFloatFromFloatWithClamping(benchmark::State& state) {
- const size_t count = state.range(0);
- const float srcMax = state.range(1);
- const float absMax = 1.413;
- std::vector<float> src(count);
- std::vector<float> dst(count);
- std::vector<float> expected(count);
-
- std::minstd_rand gen(count);
- std::uniform_real_distribution<> dis(-srcMax, srcMax);
- for (size_t i = 0; i < count; i++) {
- src[i] = dis(gen);
- expected[i] = fmin(absMax, fmax(-absMax, src[i]));
- }
-
- while (state.KeepRunning()) {
- benchmark::DoNotOptimize(src.data());
- benchmark::DoNotOptimize(dst.data());
- memcpy_to_float_from_float_with_clamping(dst.data(), src.data(), count, 1.413);
- benchmark::ClobberMemory();
- }
- if (expected != dst) {
- state.SkipWithError("Incorrect clamping!");
- }
- state.SetComplexityN(state.range(0));
- }
- BENCHMARK(BM_MemcpyToFloatFromFloatWithClamping)->RangeMultiplier(2)->Ranges({{10, 8<<12}, {1, 2}});
- static void BM_MemcpyFloat(benchmark::State& state) {
- const size_t count = state.range(0);
- std::vector<float> src(count);
- std::vector<float> dst(count);
-
- std::minstd_rand gen(count);
- std::uniform_real_distribution<> dis;
- for (size_t i = 0; i < count; i++) {
- src[i] = dis(gen);
- }
-
- while (state.KeepRunning()) {
- benchmark::DoNotOptimize(src.data());
- benchmark::DoNotOptimize(dst.data());
- memcpy(dst.data(), src.data(), count * sizeof(float));
- benchmark::ClobberMemory();
- }
- if (src != dst) {
- state.SkipWithError("Incorrect memcpy!");
- }
- state.SetComplexityN(state.range(0));
- }
- BENCHMARK(BM_MemcpyFloat)->RangeMultiplier(2)->Ranges({{10, 8<<12}});
- static void BM_MemcpyToFloatFromI16(benchmark::State& state) {
- const size_t count = state.range(0);
- std::vector<int16_t> src(count);
- std::vector<float> dst(count);
-
- std::minstd_rand gen(count);
- std::uniform_int_distribution<> dis(INT16_MIN, INT16_MAX);
- for (size_t i = 0; i < count; i++) {
- src[i] = dis(gen);
- }
-
- while (state.KeepRunning()) {
- benchmark::DoNotOptimize(src.data());
- benchmark::DoNotOptimize(dst.data());
- memcpy_to_float_from_i16(dst.data(), src.data(), count);
- benchmark::ClobberMemory();
- }
- state.SetComplexityN(state.range(0));
- }
- BENCHMARK(BM_MemcpyToFloatFromI16)->RangeMultiplier(2)->Ranges({{10, 8<<12}});
- static void BM_MemcpyToI16FromFloat(benchmark::State& state) {
- const size_t count = state.range(0);
- std::vector<float> src(count);
- std::vector<int16_t> dst(count);
-
- std::minstd_rand gen(count);
- std::uniform_real_distribution<> dis;
- for (size_t i = 0; i < count; i++) {
- src[i] = dis(gen);
- }
-
- while (state.KeepRunning()) {
- benchmark::DoNotOptimize(src.data());
- benchmark::DoNotOptimize(dst.data());
- memcpy_to_i16_from_float(dst.data(), src.data(), count);
- benchmark::ClobberMemory();
- }
- state.SetComplexityN(state.range(0));
- }
- BENCHMARK(BM_MemcpyToI16FromFloat)->RangeMultiplier(2)->Ranges({{10, 8<<12}});
- BENCHMARK_MAIN();
|