Commit 306be9f1 authored by Xiao Shi's avatar Xiao Shi Committed by Facebook Github Bot

add std::list/deque, small_vector to fbvector benchmark

Summary:
Adding a few other data structures to the benchmark. Code clean-up:
* split `insert` into `insertFront` and `pushBack`
* delete current `erase` benchmark, which is mostly spinning since `iters` can
  easily be larger than the original vector size.

Reviewed By: yfeldblum

Differential Revision: D7067000

fbshipit-source-id: 3073f7c396888787b49993468c7e6fdac70b77ac
parent f9fb46d1
This diff is collapsed.
...@@ -20,13 +20,12 @@ ...@@ -20,13 +20,12 @@
*/ */
BENCHMARK(BENCHFUN(zzInitRNG)) { BENCHMARK(BENCHFUN(zzInitRNG)) {
// LOG(INFO) << "\nTesting with type " << typeid(VECTOR).name() << "\n";
srand(seed); srand(seed);
} }
BENCHMARK(BENCHFUN(defaultCtor), iters) { BENCHMARK(BENCHFUN(defaultCtor), iters) {
FOR_EACH_RANGE (i, 0, iters) { FOR_EACH_RANGE (i, 0, iters) {
VECTOR v[4096]; VECTOR v;
doNotOptimizeAway(&v); doNotOptimizeAway(&v);
} }
} }
...@@ -37,9 +36,9 @@ void BENCHFUN(sizeCtor)(int iters, int size) { ...@@ -37,9 +36,9 @@ void BENCHFUN(sizeCtor)(int iters, int size) {
doNotOptimizeAway(&v); doNotOptimizeAway(&v);
} }
} }
BENCHMARK_PARAM(BENCHFUN(sizeCtor), 16);
BENCHMARK_PARAM(BENCHFUN(sizeCtor), 128); BENCHMARK_PARAM(BENCHFUN(sizeCtor), 128);
BENCHMARK_PARAM(BENCHFUN(sizeCtor), 1024); BENCHMARK_PARAM(BENCHFUN(sizeCtor), 1024);
BENCHMARK_PARAM(BENCHFUN(sizeCtor), 1048576);
void BENCHFUN(fillCtor)(int iters, int size) { void BENCHFUN(fillCtor)(int iters, int size) {
FOR_EACH_RANGE (i, 0, iters) { FOR_EACH_RANGE (i, 0, iters) {
...@@ -47,48 +46,51 @@ void BENCHFUN(fillCtor)(int iters, int size) { ...@@ -47,48 +46,51 @@ void BENCHFUN(fillCtor)(int iters, int size) {
doNotOptimizeAway(&v); doNotOptimizeAway(&v);
} }
} }
BENCHMARK_PARAM(BENCHFUN(fillCtor), 16);
BENCHMARK_PARAM(BENCHFUN(fillCtor), 128); BENCHMARK_PARAM(BENCHFUN(fillCtor), 128);
BENCHMARK_PARAM(BENCHFUN(fillCtor), 1024); BENCHMARK_PARAM(BENCHFUN(fillCtor), 1024);
BENCHMARK_PARAM(BENCHFUN(fillCtor), 10240);
void BENCHFUN(pushBack)(int iters, int size) { #ifndef SKIP_RESERVE
void BENCHFUN(reserve)(int iters, int size) {
auto const obj = randomObject<VECTOR::value_type>(); auto const obj = randomObject<VECTOR::value_type>();
FOR_EACH_RANGE (i, 0, iters) { FOR_EACH_RANGE (i, 0, iters) {
VECTOR v; VECTOR v(random(0U, 1U), obj);
FOR_EACH_RANGE (j, 0, size) { v.push_back(obj); } v.reserve(size);
} }
} }
BENCHMARK_PARAM(BENCHFUN(pushBack), 128); BENCHMARK_PARAM(BENCHFUN(reserve), 16);
BENCHMARK_PARAM(BENCHFUN(pushBack), 1024);
BENCHMARK_PARAM(BENCHFUN(pushBack), 10240);
BENCHMARK_PARAM(BENCHFUN(pushBack), 102400);
BENCHMARK_PARAM(BENCHFUN(pushBack), 512000);
void BENCHFUN(reserve)(int iters, int /* size */) {
auto const obj = randomObject<VECTOR::value_type>();
VECTOR v(random(0U, 10000U), obj);
FOR_EACH_RANGE (i, 0, iters) { v.reserve(random(0U, 100000U)); }
}
BENCHMARK_PARAM(BENCHFUN(reserve), 128); BENCHMARK_PARAM(BENCHFUN(reserve), 128);
BENCHMARK_PARAM(BENCHFUN(reserve), 1024); BENCHMARK_PARAM(BENCHFUN(reserve), 1024);
BENCHMARK_PARAM(BENCHFUN(reserve), 10240); #endif
void BENCHFUN(insert)(int iters, int /* size */) { void BENCHFUN(insertFront)(int iters, int initialSize) {
auto const obj1 = randomObject<VECTOR::value_type>(); BenchmarkSuspender braces;
auto const obj2 = randomObject<VECTOR::value_type>(); auto const obj = randomObject<VECTOR::value_type>();
VECTOR v(random(0U, 1U), obj1); VECTOR v(initialSize, obj);
FOR_EACH_RANGE (i, 0, iters / 100) { v.insert(v.begin(), obj2); } braces.dismissing([&]() {
FOR_EACH_RANGE (i, 0, iters) { v.insert(v.begin(), obj); }
});
} }
BENCHMARK_PARAM(BENCHFUN(insert), 100);
void BENCHFUN(erase)(int iters, int /* size */) { BENCHMARK_PARAM(BENCHFUN(insertFront), 16);
auto const obj1 = randomObject<VECTOR::value_type>(); BENCHMARK_PARAM(BENCHFUN(insertFront), 128);
VECTOR v(random(0U, 100U), obj1); BENCHMARK_PARAM(BENCHFUN(insertFront), 1024);
FOR_EACH_RANGE (i, 0, iters) { BENCHMARK_PARAM(BENCHFUN(insertFront), 10240);
if (v.empty()) { BENCHMARK_PARAM(BENCHFUN(insertFront), 102400);
continue; BENCHMARK_PARAM(BENCHFUN(insertFront), 1024000);
}
v.erase(v.begin()); void BENCHFUN(pushBack)(int iters, int initialSize) {
} BenchmarkSuspender braces;
auto const obj = randomObject<VECTOR::value_type>();
VECTOR v(initialSize, obj);
braces.dismissing([&]() {
FOR_EACH_RANGE (i, 0, iters) { v.push_back(obj); }
});
} }
BENCHMARK_PARAM(BENCHFUN(erase), 1024);
BENCHMARK_PARAM(BENCHFUN(pushBack), 16);
BENCHMARK_PARAM(BENCHFUN(pushBack), 128);
BENCHMARK_PARAM(BENCHFUN(pushBack), 1024);
BENCHMARK_PARAM(BENCHFUN(pushBack), 10240);
BENCHMARK_PARAM(BENCHFUN(pushBack), 102400);
BENCHMARK_PARAM(BENCHFUN(pushBack), 1024000);
...@@ -69,6 +69,13 @@ int randomObject<int>() { ...@@ -69,6 +69,13 @@ int randomObject<int>() {
return random(0, 1024); return random(0, 1024);
} }
template <>
std::string randomObject<std::string>() {
std::string result;
randomString(&result);
return result;
}
template <> template <>
folly::fbstring randomObject<folly::fbstring>() { folly::fbstring randomObject<folly::fbstring>() {
folly::fbstring result; folly::fbstring result;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment