2016-05-19 01:59:34 +08:00
|
|
|
|
|
|
|
#include "benchmark/benchmark_api.h"
|
|
|
|
|
2016-05-25 05:09:31 +08:00
|
|
|
#include <cstdlib>
|
2016-05-19 01:59:34 +08:00
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
#include <map>
|
|
|
|
#include <algorithm>
|
|
|
|
|
|
|
|
std::vector<int> ConstructRandomVector(int size) {
|
|
|
|
std::vector<int> v;
|
|
|
|
v.reserve(size);
|
|
|
|
for (int i = 0; i < size; ++i) {
|
|
|
|
v.push_back(rand() % size);
|
|
|
|
}
|
|
|
|
return v;
|
|
|
|
}
|
|
|
|
|
|
|
|
std::map<int, int> ConstructRandomMap(int size) {
|
|
|
|
std::map<int, int> m;
|
|
|
|
for (int i = 0; i < size; ++i) {
|
|
|
|
m.insert(std::make_pair(rand() % size, rand() % size));
|
|
|
|
}
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
|
|
|
|
void BM_Complexity_O1(benchmark::State& state) {
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
}
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Complexity_O1) -> Range(1, 1<<18) -> Complexity(benchmark::o1);
|
2016-05-19 01:59:34 +08:00
|
|
|
|
|
|
|
static void BM_Complexity_O_N(benchmark::State& state) {
|
|
|
|
auto v = ConstructRandomVector(state.range_x());
|
2016-05-24 02:50:35 +08:00
|
|
|
const int item_not_in_vector = state.range_x()*2; // Test worst case scenario (item not in vector)
|
2016-05-19 01:59:34 +08:00
|
|
|
while (state.KeepRunning()) {
|
2016-05-24 02:50:35 +08:00
|
|
|
benchmark::DoNotOptimize(std::find(v.begin(), v.end(), item_not_in_vector));
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N) -> RangeMultiplier(2) -> Range(1<<10, 1<<16) -> Complexity(benchmark::oN);
|
2016-05-26 03:18:56 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N) -> RangeMultiplier(2) -> Range(1<<10, 1<<16) -> Complexity();
|
2016-05-25 04:25:59 +08:00
|
|
|
|
2016-05-19 01:59:34 +08:00
|
|
|
static void BM_Complexity_O_N_Squared(benchmark::State& state) {
|
|
|
|
std::string s1(state.range_x(), '-');
|
|
|
|
std::string s2(state.range_x(), '-');
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
while (state.KeepRunning())
|
|
|
|
for(char& c1 : s1) {
|
|
|
|
for(char& c2 : s2) {
|
|
|
|
benchmark::DoNotOptimize(c1 = 'a');
|
|
|
|
benchmark::DoNotOptimize(c2 = 'b');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N_Squared) -> Range(1, 1<<8) -> Complexity(benchmark::oNSquared);
|
2016-05-25 04:25:59 +08:00
|
|
|
|
2016-05-19 01:59:34 +08:00
|
|
|
static void BM_Complexity_O_N_Cubed(benchmark::State& state) {
|
|
|
|
std::string s1(state.range_x(), '-');
|
|
|
|
std::string s2(state.range_x(), '-');
|
|
|
|
std::string s3(state.range_x(), '-');
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
while (state.KeepRunning())
|
|
|
|
for(char& c1 : s1) {
|
|
|
|
for(char& c2 : s2) {
|
|
|
|
for(char& c3 : s3) {
|
|
|
|
benchmark::DoNotOptimize(c1 = 'a');
|
|
|
|
benchmark::DoNotOptimize(c2 = 'b');
|
|
|
|
benchmark::DoNotOptimize(c3 = 'c');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N_Cubed) -> DenseRange(1, 8) -> Complexity(benchmark::oNCubed);
|
2016-05-19 01:59:34 +08:00
|
|
|
|
|
|
|
static void BM_Complexity_O_log_N(benchmark::State& state) {
|
|
|
|
auto m = ConstructRandomMap(state.range_x());
|
2016-05-24 02:50:35 +08:00
|
|
|
const int item_not_in_vector = state.range_x()*2; // Test worst case scenario (item not in vector)
|
2016-05-19 01:59:34 +08:00
|
|
|
while (state.KeepRunning()) {
|
2016-05-24 02:50:35 +08:00
|
|
|
benchmark::DoNotOptimize(m.find(item_not_in_vector));
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-25 04:25:59 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_log_N)
|
2016-05-24 02:12:54 +08:00
|
|
|
-> RangeMultiplier(2) -> Range(1<<10, 1<<16) -> Complexity(benchmark::oLogN);
|
2016-05-19 01:59:34 +08:00
|
|
|
|
|
|
|
static void BM_Complexity_O_N_log_N(benchmark::State& state) {
|
|
|
|
auto v = ConstructRandomVector(state.range_x());
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
std::sort(v.begin(), v.end());
|
|
|
|
}
|
2016-05-25 01:56:49 +08:00
|
|
|
state.SetComplexityN(state.range_x());
|
2016-05-19 01:59:34 +08:00
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N_log_N) -> RangeMultiplier(2) -> Range(1<<10, 1<<16) -> Complexity(benchmark::oNLogN);
|
2016-05-26 05:19:32 +08:00
|
|
|
BENCHMARK(BM_Complexity_O_N_log_N) -> RangeMultiplier(2) -> Range(1<<10, 1<<16) -> Complexity();
|
2016-05-19 01:59:34 +08:00
|
|
|
|
2016-05-21 14:55:43 +08:00
|
|
|
// Test benchmark with no range and check no complexity is calculated.
|
2016-05-19 01:59:34 +08:00
|
|
|
void BM_Extreme_Cases(benchmark::State& state) {
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
}
|
|
|
|
}
|
2016-05-24 02:12:54 +08:00
|
|
|
BENCHMARK(BM_Extreme_Cases) -> Complexity(benchmark::oNLogN);
|
2016-05-26 05:19:32 +08:00
|
|
|
BENCHMARK(BM_Extreme_Cases) -> Arg(42) -> Complexity();
|
2016-05-19 01:59:34 +08:00
|
|
|
|
2016-05-25 04:25:59 +08:00
|
|
|
BENCHMARK_MAIN()
|