неверно время отчета о тестах Google для процессора - PullRequest
0 голосов
/ 21 февраля 2019

Я использую benchmark::RegisterBenchmark для сравнительного анализа моего кода.Для простого примера у меня есть:

static void BM_Factorial(benchmark::State& state) {
  std::string x = "hello";
  for (auto _ : state) {
    uint64_t fact = 1;
    for(int i=4; i< 100000; i++)
        benchmark::DoNotOptimize(fact *= i);
  }
}

void fun(){
  // Call this multiple times
  benchmark::RegisterBenchmark("timer ", &BM_Factorial);
  // do some work
  benchmark::RunSpecifiedBenchmarks();
}

Выполняется функция init:

 int dummy = 4;
  std::string arg0 = "--help";
  std::string arg1 = "--benchmark_report_aggregates_only=true";
  std::string arg2 = "--benchmark_display_aggregates_only=true";
  std::string arg3 = "--benchmark_repetitions=10000";
  char *args[4] = {
      const_cast<char *>(arg0.c_str()), const_cast<char *>(arg1.c_str()),
      const_cast<char *>(arg2.c_str()), const_cast<char *>(arg3.c_str())};
  benchmark::Initialize(&dummy, args);

Я хочу несколько раз вызывать мою функцию сравнения из fun () с некоторыми дополнительными аргументами.Я заменил функцию эталона на факториал для простоты прямо сейчас.При этом сообщаемое время всегда равно 0. Чего мне здесь не хватает?Другое дело, что если я не напишу for (auto _ : state), он выдаст ошибку во время выполнения и завершит работу.Число сообщаемых итераций всегда равно 1000000000.

...