2017-05-02 16:43:46 +08:00
|
|
|
#ifndef NDEBUG
|
|
|
|
#define NDEBUG
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <algorithm>
|
|
|
|
#include <thread>
|
|
|
|
#include <vector>
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
#include <benchmark/benchmark.h>
|
|
|
|
#include <benchmark/benchmark_api.h>
|
|
|
|
#include <glog/logging.h>
|
|
|
|
|
2017-05-02 16:43:46 +08:00
|
|
|
#include "data_structures/concurrent/skiplist.hpp"
|
|
|
|
#include "skiplist_helper.hpp"
|
|
|
|
#include "utils/assert.hpp"
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
void Insert(benchmark::State &state) {
|
2017-05-02 16:43:46 +08:00
|
|
|
SkipList<int> skiplist;
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
const int count = SkipListHelper::InsertConcurrentSkiplistTimed(
|
|
|
|
&skiplist, 0, 10000000, state.range(1),
|
|
|
|
std::chrono::microseconds(state.range(0)));
|
|
|
|
state.SetItemsProcessed(count); // Number of processed items in one
|
|
|
|
// iteration - useful for items/per s.
|
|
|
|
state.SetIterationTime(state.range(0) * 1.0 /
|
|
|
|
1000000); // Time the iteration took - since ideally
|
|
|
|
// all threads should run and stop at the
|
|
|
|
// same time we set the time manually.
|
|
|
|
auto sl_access = skiplist.access();
|
|
|
|
while (sl_access.size()) sl_access.remove(*sl_access.begin());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Invokes the test function with two arguments, time and number of threads.
|
|
|
|
* Time is specified in microseconds.
|
|
|
|
*/
|
2017-06-21 17:29:13 +08:00
|
|
|
static void CustomArguments(benchmark::internal::Benchmark *b) {
|
2017-05-02 16:43:46 +08:00
|
|
|
for (int i = (1 << 18); i <= (1 << 20); i *= 2)
|
|
|
|
for (int j = 1; j <= 8; ++j) b->Args({i, j});
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This benchmark represents a use case of benchmarking one multi-threaded
|
|
|
|
* concurrent structure. This test assumes that all threads will start and end
|
|
|
|
* at the exact same time and will compete with each other.
|
|
|
|
*/
|
|
|
|
BENCHMARK(Insert)
|
|
|
|
->Apply(CustomArguments) // Set custom arguments.
|
|
|
|
->Unit(benchmark::kMicrosecond)
|
|
|
|
->UseManualTime() // Don't calculate real-time but depend on function
|
|
|
|
// providing the execution time.
|
|
|
|
->Repetitions(3)
|
|
|
|
->ReportAggregatesOnly(1);
|
|
|
|
|
2017-06-21 17:29:13 +08:00
|
|
|
int main(int argc, char **argv) {
|
|
|
|
google::InitGoogleLogging(argv[0]);
|
2017-05-02 16:43:46 +08:00
|
|
|
::benchmark::Initialize(&argc, argv);
|
|
|
|
::benchmark::RunSpecifiedBenchmarks();
|
|
|
|
return 0;
|
|
|
|
}
|