2016-08-02 8 views
1

В проекте я начал использовать google/benchmark от https://github.com/google/benchmark.git тег v1.0.0.google benchmark: Assertion `has_range_x_ 'не удалось

Я бегу очень простой тест

#include <benchmark/benchmark.h> 
#include <cstring> 

static void BM_memcpy(benchmark::State& state) { 
    char* src = new char[state.range_x()]; char* dst = new char[state.range_x()]; 
    memset(src, 'x', state.range_x()); 
    while (state.KeepRunning()) 
    memcpy(dst, src, state.range_x()); 
    state.SetBytesProcessed(int64_t(state.iterations()) * 
          int64_t(state.range_x())); 
    delete[] src; 
    delete[] dst; 
} 
BENCHMARK(BM_memcpy)->Arg(8)->Arg(64)->Arg(512)->Arg(1<<10)->Arg(8<<10); 

// Register the function as a benchmark 
BENCHMARK(BM_memcpy); 

BENCHMARK_MAIN(); 

, но я получаю ошибку

./bench/simple-benchmark 
Run on (8 X 4000 MHz CPU s) 
2016-08-02 18:22:30 
Benchmark    Time   CPU Iterations 
----------------------------------------------------- 
BM_memcpy/8    9 ns   9 ns 79545455  877MB/s 
BM_memcpy/64   9 ns   9 ns 56451613 6.67615GB/s 
BM_memcpy/512   21 ns   21 ns 33018868 23.0185GB/s 
BM_memcpy/1024   30 ns   29 ns 23648649 32.4039GB/s 
BM_memcpy/8k   516 ns  514 ns 1346154 14.8415GB/s 
simple-idl-benchmark: /usr/local/include/benchmark/benchmark_api.h:417: int benchmark::State::range_x() const: Assertion `has_range_x_' failed. 

Я попытался мастер и старые теги, но я всегда получаю это утверждение. Я использую gcc 5.4.0 для debian/testing как для тестовой библиотеки, так и для простого эталонного исполняемого файла.

Мне кажется, что он не может обнаружить конец списка аргументов, и он утверждает. Но что не так? Как предотвратить это?

+0

Вам не нужно определять диапазон, например: BENCHMARK (BM_memcpy) -> Диапазон (8, 8 << 10); ??? –

+0

Собственно, согласно документации, это должно быть почти то же самое. Я получаю такое же утверждение. –

+0

Вы включаете выделение и обнуление в свое время. Вы можете получить точные результаты с более коротким интервалом, если у вас не было этого накладного расхода, особенно. если вы планируете протестировать очень большие буферы. –

ответ

1

Вы регистрируете тест дважды (звонки BENCHMARK), но во второй раз вы не предоставляете Arg. Т.е. вы вызываете его, не устанавливая диапазон, как утверждает утверждение.