/*
- * Copyright 2014 Facebook, Inc.
+ * Copyright 2015 Facebook, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* limitations under the License.
*/
-#include "folly/Benchmark.h"
-#include "folly/Foreach.h"
-#include "folly/String.h"
+#include <folly/Benchmark.h>
+#include <folly/Foreach.h>
+#include <folly/String.h>
+#include <algorithm>
#include <iostream>
+#include <numeric>
+#include <random>
+#include <vector>
using namespace folly;
using namespace std;
sleep(1);
}
+BENCHMARK_DRAW_LINE()
+
+BENCHMARK(noMulti) {
+ fun();
+}
+
+BENCHMARK_MULTI(multiSimple) {
+ FOR_EACH_RANGE (i, 0, 10) {
+ fun();
+ }
+ return 10;
+}
+
+BENCHMARK_RELATIVE_MULTI(multiSimpleRel) {
+ FOR_EACH_RANGE (i, 0, 10) {
+ fun();
+ fun();
+ }
+ return 10;
+}
+
+BENCHMARK_MULTI(multiIterArgs, iter) {
+ FOR_EACH_RANGE (i, 0, 10 * iter) {
+ fun();
+ }
+ return 10 * iter;
+}
+
+BENCHMARK_RELATIVE_MULTI(multiIterArgsRel, iter) {
+ FOR_EACH_RANGE (i, 0, 10 * iter) {
+ fun();
+ fun();
+ }
+ return 10 * iter;
+}
+
+unsigned paramMulti(unsigned iter, unsigned num) {
+ for (unsigned i = 0; i < iter; ++i) {
+ for (unsigned j = 0; j < num; ++j) {
+ fun();
+ }
+ }
+ return num * iter;
+}
+
+unsigned paramMultiRel(unsigned iter, unsigned num) {
+ for (unsigned i = 0; i < iter; ++i) {
+ for (unsigned j = 0; j < num; ++j) {
+ fun();
+ fun();
+ }
+ }
+ return num * iter;
+}
+
+BENCHMARK_PARAM_MULTI(paramMulti, 1);
+BENCHMARK_RELATIVE_PARAM_MULTI(paramMultiRel, 1);
+
+BENCHMARK_PARAM_MULTI(paramMulti, 5);
+BENCHMARK_RELATIVE_PARAM_MULTI(paramMultiRel, 5);
+
+BENCHMARK_DRAW_LINE();
+
+BENCHMARK(BenchmarkSuspender_dismissing_void, iter) {
+ BenchmarkSuspender braces;
+ mt19937_64 rng;
+ while (iter--) {
+ vector<size_t> v(1 << 12, 0);
+ iota(v.begin(), v.end(), 0);
+ shuffle(v.begin(), v.end(), rng);
+ braces.dismissing([&] {
+ sort(v.begin(), v.end());
+ });
+ }
+}
+
+BENCHMARK(BenchmarkSuspender_dismissing_value, iter) {
+ BenchmarkSuspender braces;
+ mt19937_64 rng;
+ while (iter--) {
+ vector<size_t> v(1 << 12, 0);
+ iota(v.begin(), v.end(), 0);
+ shuffle(v.begin(), v.end(), rng);
+ auto s = braces.dismissing([&] {
+ sort(v.begin(), v.end());
+ return accumulate(v.begin(), v.end(), 0, [](size_t a, size_t e) {
+ return a + e;
+ });
+ });
+ doNotOptimizeAway(s);
+ }
+}
+
int main(int argc, char** argv) {
- google::ParseCommandLineFlags(&argc, &argv, true);
+ gflags::ParseCommandLineFlags(&argc, &argv, true);
runBenchmarks();
runBenchmarksOnFlag();
}