📈 reducing benchmark variance (#365)

This commit is contained in:
Niels 2016-11-23 08:47:40 +01:00
parent c34b41acd6
commit ed611119d9
2 changed files with 45 additions and 1 deletions

View file

@ -95,7 +95,7 @@ pretty:
# benchmarks # benchmarks
json_benchmarks: benchmarks/benchmarks.cpp benchmarks/benchpress.hpp benchmarks/cxxopts.hpp src/json.hpp json_benchmarks: benchmarks/benchmarks.cpp benchmarks/benchpress.hpp benchmarks/cxxopts.hpp src/json.hpp
cd benchmarks/files/numbers ; python generate.py cd benchmarks/files/numbers ; python generate.py
$(CXX) -std=c++11 $(CXXFLAGS) -DNDEBUG -O3 -flto -I src -I benchmarks $< $(LDFLAGS) -o $@ $(CXX) -std=c++11 -pthread $(CXXFLAGS) -DNDEBUG -O3 -flto -I src -I benchmarks $< $(LDFLAGS) -o $@
./json_benchmarks ./json_benchmarks

View file

@ -3,14 +3,36 @@
#include <fstream> #include <fstream>
#include <benchpress.hpp> #include <benchpress.hpp>
#include <json.hpp> #include <json.hpp>
#include <pthread.h>
#include <thread>
struct StartUp
{
StartUp()
{
#ifndef __llvm__
// pin thread to a single CPU
cpu_set_t cpuset;
pthread_t thread;
thread = pthread_self();
CPU_ZERO(&cpuset);
CPU_SET(std::thread::hardware_concurrency() - 1, &cpuset);
pthread_setaffinity_np(thread, sizeof(cpu_set_t), &cpuset);
#endif
}
};
StartUp startup;
BENCHMARK("parse jeopardy.json", [](benchpress::context* ctx) BENCHMARK("parse jeopardy.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/jeopardy/jeopardy.json"); std::ifstream input_file("benchmarks/files/jeopardy/jeopardy.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -18,9 +40,12 @@ BENCHMARK("parse canada.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/nativejson-benchmark/canada.json"); std::ifstream input_file("benchmarks/files/nativejson-benchmark/canada.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -28,9 +53,12 @@ BENCHMARK("parse citm_catalog.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/nativejson-benchmark/citm_catalog.json"); std::ifstream input_file("benchmarks/files/nativejson-benchmark/citm_catalog.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -38,9 +66,12 @@ BENCHMARK("parse twitter.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/nativejson-benchmark/twitter.json"); std::ifstream input_file("benchmarks/files/nativejson-benchmark/twitter.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -48,9 +79,12 @@ BENCHMARK("parse numbers/floats.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/numbers/floats.json"); std::ifstream input_file("benchmarks/files/numbers/floats.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -58,9 +92,12 @@ BENCHMARK("parse numbers/signed_ints.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/numbers/signed_ints.json"); std::ifstream input_file("benchmarks/files/numbers/signed_ints.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -68,9 +105,12 @@ BENCHMARK("parse numbers/unsigned_ints.json", [](benchpress::context* ctx)
{ {
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->stop_timer();
std::ifstream input_file("benchmarks/files/numbers/unsigned_ints.json"); std::ifstream input_file("benchmarks/files/numbers/unsigned_ints.json");
nlohmann::json j; nlohmann::json j;
ctx->start_timer();
j << input_file; j << input_file;
ctx->stop_timer();
} }
}) })
@ -84,7 +124,9 @@ BENCHMARK("dump jeopardy.json", [](benchpress::context* ctx)
ctx->reset_timer(); ctx->reset_timer();
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->start_timer();
output_file << j; output_file << j;
ctx->stop_timer();
} }
std::remove("jeopardy.dump.json"); std::remove("jeopardy.dump.json");
@ -100,7 +142,9 @@ BENCHMARK("dump jeopardy.json with indent", [](benchpress::context* ctx)
ctx->reset_timer(); ctx->reset_timer();
for (size_t i = 0; i < ctx->num_iterations(); ++i) for (size_t i = 0; i < ctx->num_iterations(); ++i)
{ {
ctx->start_timer();
output_file << std::setw(4) << j; output_file << std::setw(4) << j;
ctx->stop_timer();
} }
std::remove("jeopardy.dump.json"); std::remove("jeopardy.dump.json");