2018-08-31 21:13:18 +08:00
|
|
|
#include <benchmark/benchmark.h>
|
|
|
|
|
|
|
|
#include "query/frontend/ast/ast.hpp"
|
|
|
|
#include "query/interpret/eval.hpp"
|
|
|
|
|
|
|
|
static void BenchmarkCoalesceCallWithNulls(benchmark::State &state) {
|
|
|
|
int64_t num_args = state.range(0);
|
|
|
|
query::AstStorage ast_storage;
|
|
|
|
std::vector<query::Expression *> arguments;
|
|
|
|
arguments.reserve(num_args);
|
|
|
|
for (int64_t i = 0; i < num_args; ++i) {
|
|
|
|
arguments.emplace_back(
|
|
|
|
ast_storage.Create<query::PrimitiveLiteral>(query::TypedValue::Null));
|
|
|
|
}
|
|
|
|
auto *function = ast_storage.Create<query::Function>("COALESCE", arguments);
|
|
|
|
query::Frame frame(0);
|
|
|
|
database::GraphDbAccessor *dba = nullptr;
|
|
|
|
query::Context context(*dba);
|
2018-09-05 00:02:30 +08:00
|
|
|
query::ExpressionEvaluator evaluator(
|
2018-09-11 19:32:25 +08:00
|
|
|
&frame, context.symbol_table_, context.evaluation_context_,
|
|
|
|
&context.db_accessor_, query::GraphView::OLD);
|
2018-08-31 21:13:18 +08:00
|
|
|
while (state.KeepRunning()) {
|
|
|
|
function->Accept(evaluator);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void BenchmarkCoalesceCallWithStrings(benchmark::State &state) {
|
|
|
|
int64_t num_args = state.range(0);
|
|
|
|
query::AstStorage ast_storage;
|
|
|
|
std::vector<query::Expression *> arguments;
|
|
|
|
arguments.reserve(num_args);
|
|
|
|
for (int64_t i = 0; i < num_args; ++i) {
|
|
|
|
std::string val = "some_string " + std::to_string(i);
|
|
|
|
arguments.emplace_back(ast_storage.Create<query::PrimitiveLiteral>(val));
|
|
|
|
}
|
|
|
|
auto *function = ast_storage.Create<query::Function>("COALESCE", arguments);
|
|
|
|
query::Frame frame(0);
|
|
|
|
database::GraphDbAccessor *dba = nullptr;
|
|
|
|
query::Context context(*dba);
|
2018-09-05 00:02:30 +08:00
|
|
|
query::ExpressionEvaluator evaluator(
|
2018-09-11 19:32:25 +08:00
|
|
|
&frame, context.symbol_table_, context.evaluation_context_,
|
|
|
|
&context.db_accessor_, query::GraphView::OLD);
|
2018-08-31 21:13:18 +08:00
|
|
|
while (state.KeepRunning()) {
|
|
|
|
function->Accept(evaluator);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// We are interested in benchmarking the usual amount of arguments
|
|
|
|
BENCHMARK(BenchmarkCoalesceCallWithNulls)
|
|
|
|
->RangeMultiplier(2)
|
|
|
|
->Range(1, 256)
|
|
|
|
->ThreadRange(1, 16);
|
|
|
|
|
|
|
|
BENCHMARK(BenchmarkCoalesceCallWithStrings)
|
|
|
|
->RangeMultiplier(2)
|
|
|
|
->Range(1, 256)
|
|
|
|
->ThreadRange(1, 16);
|
|
|
|
|
|
|
|
BENCHMARK_MAIN();
|