2021-10-26 14:53:56 +08:00
|
|
|
// Copyright 2021 Memgraph Ltd.
|
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
2020-05-05 16:29:46 +08:00
|
|
|
#include <chrono>
|
|
|
|
#include <iostream>
|
|
|
|
#include <map>
|
|
|
|
#include <random>
|
|
|
|
|
|
|
|
#include <benchmark/benchmark.h>
|
|
|
|
|
|
|
|
#include "storage/v2/property_store.hpp"
|
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// PropertyStore Set
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// NOLINTNEXTLINE(google-runtime-references)
|
|
|
|
static void PropertyStoreSet(benchmark::State &state) {
|
|
|
|
storage::PropertyStore store;
|
2022-01-18 19:51:27 +08:00
|
|
|
std::mt19937 gen(state.thread_index());
|
2020-05-05 16:29:46 +08:00
|
|
|
std::uniform_int_distribution<uint64_t> dist(0, state.range(0) - 1);
|
|
|
|
uint64_t counter = 0;
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(dist(gen));
|
|
|
|
store.SetProperty(prop, storage::PropertyValue(42));
|
|
|
|
++counter;
|
|
|
|
}
|
|
|
|
state.SetItemsProcessed(counter);
|
|
|
|
}
|
|
|
|
|
2021-02-18 22:32:43 +08:00
|
|
|
BENCHMARK(PropertyStoreSet)->RangeMultiplier(2)->Range(1, 1024)->Unit(benchmark::kNanosecond)->UseRealTime();
|
2020-05-05 16:29:46 +08:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// std::map Set
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// NOLINTNEXTLINE(google-runtime-references)
|
|
|
|
static void StdMapSet(benchmark::State &state) {
|
|
|
|
std::map<storage::PropertyId, storage::PropertyValue> store;
|
2022-01-18 19:51:27 +08:00
|
|
|
std::mt19937 gen(state.thread_index());
|
2020-05-05 16:29:46 +08:00
|
|
|
std::uniform_int_distribution<uint64_t> dist(0, state.range(0) - 1);
|
|
|
|
uint64_t counter = 0;
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(dist(gen));
|
|
|
|
store.emplace(prop, storage::PropertyValue(42));
|
|
|
|
++counter;
|
|
|
|
}
|
|
|
|
state.SetItemsProcessed(counter);
|
|
|
|
}
|
|
|
|
|
2021-02-18 22:32:43 +08:00
|
|
|
BENCHMARK(StdMapSet)->RangeMultiplier(2)->Range(1, 1024)->Unit(benchmark::kNanosecond)->UseRealTime();
|
2020-05-05 16:29:46 +08:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// PropertyStore Get
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// NOLINTNEXTLINE(google-runtime-references)
|
|
|
|
static void PropertyStoreGet(benchmark::State &state) {
|
|
|
|
storage::PropertyStore store;
|
|
|
|
for (uint64_t i = 0; i < state.range(0); ++i) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(i);
|
|
|
|
store.SetProperty(prop, storage::PropertyValue(0));
|
|
|
|
}
|
2022-01-18 19:51:27 +08:00
|
|
|
std::mt19937 gen(state.thread_index());
|
2020-05-05 16:29:46 +08:00
|
|
|
std::uniform_int_distribution<uint64_t> dist(0, state.range(0) - 1);
|
|
|
|
uint64_t counter = 0;
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(dist(gen));
|
|
|
|
store.GetProperty(prop);
|
|
|
|
++counter;
|
|
|
|
}
|
|
|
|
state.SetItemsProcessed(counter);
|
|
|
|
}
|
|
|
|
|
2021-02-18 22:32:43 +08:00
|
|
|
BENCHMARK(PropertyStoreGet)->RangeMultiplier(2)->Range(1, 1024)->Unit(benchmark::kNanosecond)->UseRealTime();
|
2020-05-05 16:29:46 +08:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
// std::map Get
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
// NOLINTNEXTLINE(google-runtime-references)
|
|
|
|
static void StdMapGet(benchmark::State &state) {
|
|
|
|
std::map<storage::PropertyId, storage::PropertyValue> store;
|
|
|
|
for (uint64_t i = 0; i < state.range(0); ++i) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(i);
|
|
|
|
store.emplace(prop, storage::PropertyValue(0));
|
|
|
|
}
|
2022-01-18 19:51:27 +08:00
|
|
|
std::mt19937 gen(state.thread_index());
|
2020-05-05 16:29:46 +08:00
|
|
|
std::uniform_int_distribution<uint64_t> dist(0, state.range(0) - 1);
|
|
|
|
uint64_t counter = 0;
|
|
|
|
while (state.KeepRunning()) {
|
|
|
|
auto prop = storage::PropertyId::FromUint(dist(gen));
|
|
|
|
store.find(prop);
|
|
|
|
++counter;
|
|
|
|
}
|
|
|
|
state.SetItemsProcessed(counter);
|
|
|
|
}
|
|
|
|
|
2021-02-18 22:32:43 +08:00
|
|
|
BENCHMARK(StdMapGet)->RangeMultiplier(2)->Range(1, 1024)->Unit(benchmark::kNanosecond)->UseRealTime();
|
2020-05-05 16:29:46 +08:00
|
|
|
|
|
|
|
BENCHMARK_MAIN();
|