memgraph/tests/benchmark/data_structures/concurrent/skiplist_insert.cpp
Dominik Gleich 487f429d5b Add concurrent benchmarks for skiplist.
Summary: Skiplist benchmark and refactor testing infrastructure.

Reviewers: mferencevic, buda

Reviewed By: buda

Subscribers: pullbot

Differential Revision: https://phabricator.memgraph.io/D103
2017-05-03 11:03:23 +02:00

64 lines
2.1 KiB
C++

#ifndef NDEBUG
#define NDEBUG
#endif
#include <algorithm>
#include <thread>
#include <vector>
#include "benchmark/benchmark.h"
#include "benchmark/benchmark_api.h"
#include "data_structures/concurrent/skiplist.hpp"
#include "logging/default.hpp"
#include "logging/streams/stderr.hpp"
#include "skiplist_helper.hpp"
#include "utils/assert.hpp"
void Insert(benchmark::State& state) {
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.
*/
static void CustomArguments(benchmark::internal::Benchmark* b) {
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);
int main(int argc, char** argv) {
logging::init_async();
logging::log->pipe(std::make_unique<Stderr>());
::benchmark::Initialize(&argc, argv);
::benchmark::RunSpecifiedBenchmarks();
return 0;
}