2016-11-23 00:42:24 +08:00
|
|
|
#include "logging/default.hpp"
|
|
|
|
#include "logging/streams/stdout.hpp"
|
|
|
|
#include "query/preprocesor.hpp"
|
2016-12-22 22:51:16 +08:00
|
|
|
#include "utils/time/timer.hpp"
|
2016-11-23 00:42:24 +08:00
|
|
|
|
|
|
|
#include "benchmark/benchmark_api.h"
|
|
|
|
#include "yaml-cpp/yaml.h"
|
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
auto BM_Strip = [](benchmark::State &state, auto &function, std::string query) {
|
|
|
|
while (state.KeepRunning())
|
|
|
|
{
|
|
|
|
for (int start = 0; start < state.range(0); start++)
|
|
|
|
{
|
|
|
|
function(query);
|
|
|
|
}
|
2016-11-23 00:42:24 +08:00
|
|
|
}
|
2016-12-22 22:51:16 +08:00
|
|
|
state.SetComplexityN(state.range(0));
|
2016-11-23 00:42:24 +08:00
|
|
|
};
|
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
logging::init_async();
|
|
|
|
logging::log->pipe(std::make_unique<Stdout>());
|
|
|
|
|
|
|
|
YAML::Node dataset = YAML::LoadFile(
|
|
|
|
"../../tests/data/cypher_queries/stripper/query_dict.yaml");
|
|
|
|
|
|
|
|
QueryPreprocessor processor;
|
|
|
|
using std::placeholders::_1;
|
|
|
|
std::function<QueryStripped(const std::string &query)> preprocess =
|
|
|
|
std::bind(&QueryPreprocessor::preprocess, &processor, _1);
|
|
|
|
|
|
|
|
auto tests = dataset["benchmark_queries"].as<std::vector<std::string>>();
|
|
|
|
for (auto &test : tests)
|
|
|
|
{
|
|
|
|
auto *benchmark = benchmark::RegisterBenchmark(test.c_str(), BM_Strip,
|
|
|
|
preprocess, test)
|
|
|
|
->RangeMultiplier(2)
|
|
|
|
->Range(1, 8 << 10)
|
|
|
|
->Complexity(benchmark::oN);
|
|
|
|
}
|
2016-11-23 00:42:24 +08:00
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
benchmark::Initialize(&argc, argv);
|
|
|
|
benchmark::RunSpecifiedBenchmarks();
|
2016-11-23 00:42:24 +08:00
|
|
|
|
2016-12-22 22:51:16 +08:00
|
|
|
return 0;
|
2016-11-23 00:42:24 +08:00
|
|
|
}
|