mirror of
https://github.com/gnss-sdr/gnss-sdr
synced 2025-01-09 17:00:34 +00:00
205 lines
6.7 KiB
C++
205 lines
6.7 KiB
C++
/*!
|
|
* \file benchmark_detector.cc
|
|
* \brief Benchmark for preamble detection implementations
|
|
* \author Carles Fernandez-Prades, 2020. cfernandez(at)cttc.es
|
|
*
|
|
*
|
|
* -----------------------------------------------------------------------------
|
|
*
|
|
* GNSS-SDR is a Global Navigation Satellite System software-defined receiver.
|
|
* This file is part of GNSS-SDR.
|
|
*
|
|
* Copyright (C) 2020 (see AUTHORS file for a list of contributors)
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* -----------------------------------------------------------------------------
|
|
*/
|
|
|
|
#include "GPS_L1_CA.h"
|
|
#include <benchmark/benchmark.h>
|
|
#include <algorithm> // for std::generate
|
|
#include <array>
|
|
#include <cmath> // std::for signbit
|
|
#include <cstdint>
|
|
#include <functional> // for std::plus
|
|
#include <numeric> // for std::accumulate, std::inner_product
|
|
#include <random>
|
|
#include <vector>
|
|
#if COMPILER_HAS_STD_TRANSFORM_REDUCE_WITH_POLICY
|
|
#include <execution>
|
|
#endif
|
|
|
|
void bm_forloop(benchmark::State& state)
|
|
{
|
|
std::vector<float> d_symbol_history(GPS_CA_PREAMBLE_LENGTH_SYMBOLS, 0.0);
|
|
std::array<int32_t, GPS_CA_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
|
|
|
|
// fill the inputs
|
|
std::random_device rd;
|
|
std::default_random_engine e2(rd());
|
|
std::uniform_real_distribution<> dist(-1.0, 1.0);
|
|
std::generate(d_symbol_history.begin(), d_symbol_history.end(), [&dist, &e2]() { return dist(e2); });
|
|
|
|
std::generate(d_preamble_samples.begin(), d_preamble_samples.end(), [n = 0]() mutable { return (GPS_CA_PREAMBLE_SYMBOLS_STR[n++] == '1' ? 1 : -1); });
|
|
|
|
int32_t corr_value = 0;
|
|
while (state.KeepRunning())
|
|
{
|
|
for (size_t i = 0; i < d_preamble_samples.size(); i++)
|
|
{
|
|
if (d_symbol_history[i] < 0.0)
|
|
{
|
|
corr_value -= d_preamble_samples[i];
|
|
}
|
|
else
|
|
{
|
|
corr_value += d_preamble_samples[i];
|
|
}
|
|
}
|
|
}
|
|
if (corr_value)
|
|
{
|
|
// avoidl warning
|
|
};
|
|
}
|
|
|
|
|
|
void bm_accumulate(benchmark::State& state)
|
|
{
|
|
std::vector<float> d_symbol_history(GPS_CA_PREAMBLE_LENGTH_SYMBOLS, 0.0);
|
|
std::array<int32_t, GPS_CA_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
|
|
|
|
// fill the inputs
|
|
std::random_device rd;
|
|
std::default_random_engine e2(rd());
|
|
std::uniform_real_distribution<> dist(-1.0, 1.0);
|
|
std::generate(d_symbol_history.begin(), d_symbol_history.end(), [&dist, &e2]() { return dist(e2); });
|
|
|
|
std::generate(d_preamble_samples.begin(), d_preamble_samples.end(), [n = 0]() mutable { return (GPS_CA_PREAMBLE_SYMBOLS_STR[n++] == '1' ? 1 : -1); });
|
|
|
|
int32_t corr_value = 0;
|
|
while (state.KeepRunning())
|
|
{
|
|
corr_value += std::accumulate(d_symbol_history.begin(),
|
|
d_symbol_history.end(),
|
|
0,
|
|
[&d_preamble_samples, n = 0](float a, float b) mutable { return (b > 0.0 ? a + d_preamble_samples[n++] : a - d_preamble_samples[n++]); });
|
|
}
|
|
if (corr_value)
|
|
{
|
|
// avoidl warning
|
|
};
|
|
}
|
|
|
|
|
|
void bm_inner_product(benchmark::State& state)
|
|
{
|
|
std::vector<float> d_symbol_history(GPS_CA_PREAMBLE_LENGTH_SYMBOLS, 0.0);
|
|
std::array<int32_t, GPS_CA_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
|
|
|
|
// fill the inputs
|
|
std::random_device rd;
|
|
std::default_random_engine e2(rd());
|
|
std::uniform_real_distribution<> dist(-1.0, 1.0);
|
|
std::generate(d_symbol_history.begin(), d_symbol_history.end(), [&dist, &e2]() { return dist(e2); });
|
|
|
|
std::generate(d_preamble_samples.begin(), d_preamble_samples.end(), [n = 0]() mutable { return (GPS_CA_PREAMBLE_SYMBOLS_STR[n++] == '1' ? 1 : -1); });
|
|
|
|
int32_t corr_value = 0;
|
|
while (state.KeepRunning())
|
|
{
|
|
corr_value += std::inner_product(d_symbol_history.begin(),
|
|
d_symbol_history.end(),
|
|
d_preamble_samples.begin(),
|
|
0,
|
|
#if COMPILER_HAS_STD_PLUS_VOID
|
|
std::plus<>(),
|
|
#else
|
|
std::plus<int32_t>(),
|
|
#endif
|
|
[](float a, int32_t b) { return (std::signbit(a) ? -b : b); });
|
|
}
|
|
if (corr_value)
|
|
{
|
|
// avoidl warning
|
|
};
|
|
}
|
|
|
|
|
|
#if COMPILER_HAS_STD_TRANSFORM_REDUCE
|
|
void bm_transform_reduce(benchmark::State& state)
|
|
{
|
|
std::vector<float> d_symbol_history(GPS_CA_PREAMBLE_LENGTH_SYMBOLS, 0.0);
|
|
std::array<int32_t, GPS_CA_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
|
|
|
|
// fill the inputs
|
|
std::random_device rd;
|
|
std::default_random_engine e2(rd());
|
|
std::uniform_real_distribution<> dist(-1.0, 1.0);
|
|
std::generate(d_symbol_history.begin(), d_symbol_history.end(), [&dist, &e2]() { return dist(e2); });
|
|
|
|
std::generate(d_preamble_samples.begin(), d_preamble_samples.end(), [n = 0]() mutable { return (GPS_CA_PREAMBLE_SYMBOLS_STR[n++] == '1' ? 1 : -1); });
|
|
|
|
int32_t corr_value = 0;
|
|
while (state.KeepRunning())
|
|
{
|
|
corr_value += std::transform_reduce(d_symbol_history.begin(),
|
|
d_symbol_history.end(),
|
|
d_preamble_samples.begin(),
|
|
0,
|
|
std::plus<>(),
|
|
[](auto a, auto b) { return (std::signbit(a) ? -b : b); });
|
|
}
|
|
if (corr_value)
|
|
{
|
|
// avoidl warning
|
|
};
|
|
}
|
|
#endif
|
|
|
|
|
|
#if COMPILER_HAS_STD_TRANSFORM_REDUCE_WITH_POLICY
|
|
void bm_transform_reduce_policy(benchmark::State& state)
|
|
{
|
|
std::vector<float> d_symbol_history(GPS_CA_PREAMBLE_LENGTH_SYMBOLS, 0.0);
|
|
std::array<int32_t, GPS_CA_PREAMBLE_LENGTH_SYMBOLS> d_preamble_samples{};
|
|
|
|
// fill the inputs
|
|
std::random_device rd;
|
|
std::default_random_engine e2(rd());
|
|
std::uniform_real_distribution<> dist(-1.0, 1.0);
|
|
std::generate(d_symbol_history.begin(), d_symbol_history.end(), [&dist, &e2]() { return dist(e2); });
|
|
|
|
std::generate(d_preamble_samples.begin(), d_preamble_samples.end(), [n = 0]() mutable { return (GPS_CA_PREAMBLE_SYMBOLS_STR[n++] == '1' ? 1 : -1); });
|
|
|
|
int32_t corr_value = 0;
|
|
while (state.KeepRunning())
|
|
{
|
|
corr_value += std::transform_reduce(
|
|
std::execution::par,
|
|
d_symbol_history.begin(),
|
|
d_symbol_history.end(),
|
|
d_preamble_samples.begin(),
|
|
0,
|
|
std::plus<>(),
|
|
[](auto a, auto b) { return (std::signbit(a) ? -b : b); });
|
|
}
|
|
if (corr_value)
|
|
{
|
|
// avoidl warning
|
|
};
|
|
}
|
|
#endif
|
|
|
|
|
|
BENCHMARK(bm_forloop);
|
|
BENCHMARK(bm_accumulate);
|
|
BENCHMARK(bm_inner_product);
|
|
#if COMPILER_HAS_STD_TRANSFORM_REDUCE
|
|
BENCHMARK(bm_transform_reduce);
|
|
#endif
|
|
#if COMPILER_HAS_STD_TRANSFORM_REDUCE_WITH_POLICY
|
|
BENCHMARK(bm_transform_reduce_policy);
|
|
#endif
|
|
BENCHMARK_MAIN();
|