34 double min_sample_duration_sec) -> std::size_t {
35 std::size_t iterations = 1;
36 constexpr std::size_t trials = 10;
37 for (std::size_t i = 0; i < trials; ++i) {
38 constexpr std::size_t samples = 2;
40 bench_case, cond, measurer_name, iterations, samples, 0);
41 const double duration_sec = data.durations().at(0).at(1).seconds();
42 if (duration_sec > min_sample_duration_sec) {
46 const double multiplier =
48 min_sample_duration_sec / std::max(duration_sec, 1e-9), 10.0) *
50 constexpr double max_iterations = 1e+6;
51 iterations =
static_cast<std::size_t
>(std::min(
52 max_iterations,
static_cast<double>(iterations) * multiplier));
Class of conditions of benchmarks.
Interface of cases in benchmarks.
Class of names of measurers.
Declaration of determine_iterations function.
Definition of Duration class.
Declaration of measure_once function.
Definition of Measurement class.
Namespace of classes to measure time in benchmarks.
auto measure_once(bench_impl::IBenchmarkCase *bench_case, const BenchmarkCondition &cond, const MeasurerName &measurer_name, std::size_t iterations, std::size_t samples, std::size_t warming_up_samples) -> Measurement
Measure durations once.
auto determine_iterations(bench_impl::IBenchmarkCase *bench_case, const BenchmarkCondition &cond, const MeasurerName &measurer_name, double min_sample_duration_sec) -> std::size_t
Determine number of iterations.
Namespace of stat_bench source codes.