| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 |
- /*
- * Copyright (c) Contributors to the Open 3D Engine Project.
- * For complete copyright and license terms please see the LICENSE at the root of this distribution.
- *
- * SPDX-License-Identifier: Apache-2.0 OR MIT
- *
- */
- #include <AzCore/DOM/DomUtils.h>
- #include <AzCore/DOM/DomValue.h>
- #include <AzCore/Name/NameDictionary.h>
- #include <AzCore/UnitTest/TestTypes.h>
- #include <Tests/DOM/DomFixtures.h>
- namespace AZ::Dom::Benchmark
- {
- class DomValueBenchmark : public Tests::DomBenchmarkFixture
- {
- };
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueGetType_UsingVariantIndex)(benchmark::State& state)
- {
- Value intValue(5);
- Value boolValue(true);
- Value objValue(Type::Object);
- Value nodeValue(Type::Node);
- Value arrValue(Type::Array);
- Value uintValue(5u);
- Value doubleValue(4.0);
- Value stringValue("foo", true);
- for ([[maybe_unused]] auto _ : state)
- {
- (intValue.GetType());
- (boolValue.GetType());
- (objValue.GetType());
- (nodeValue.GetType());
- (arrValue.GetType());
- (uintValue.GetType());
- (doubleValue.GetType());
- (stringValue.GetType());
- }
- state.SetItemsProcessed(8 * state.iterations());
- }
- BENCHMARK_REGISTER_F(DomValueBenchmark, AzDomValueGetType_UsingVariantIndex);
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueGetType_UsingVariantVisit)(benchmark::State& state)
- {
- Value intValue(5);
- Value boolValue(true);
- Value objValue(Type::Object);
- Value nodeValue(Type::Node);
- Value arrValue(Type::Array);
- Value uintValue(5u);
- Value doubleValue(4.0);
- Value stringValue("foo", true);
- auto getTypeViaVisit = [](const Value& value)
- {
- return AZStd::visit(
- [](auto&& value) constexpr -> Type
- {
- using CurrentType = AZStd::decay_t<decltype(value)>;
- if constexpr (AZStd::is_same_v<CurrentType, AZStd::monostate>)
- {
- return Type::Null;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, AZ::s64>)
- {
- return Type::Int64;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, AZ::u64>)
- {
- return Type::Uint64;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, double>)
- {
- return Type::Double;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, bool>)
- {
- return Type::Bool;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, AZStd::string_view>)
- {
- return Type::String;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, Value::SharedStringType>)
- {
- return Type::String;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, Value::ShortStringType>)
- {
- return Type::String;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, ObjectPtr>)
- {
- return Type::Object;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, ArrayPtr>)
- {
- return Type::Array;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, NodePtr>)
- {
- return Type::Node;
- }
- else if constexpr (AZStd::is_same_v<CurrentType, Value::OpaqueStorageType>)
- {
- return Type::Opaque;
- }
- else
- {
- AZ_Assert(false, "AZ::Dom::Value::GetType: m_value has an unexpected type");
- }
- },
- value.GetInternalValue());
- };
- for ([[maybe_unused]] auto _ : state)
- {
- (getTypeViaVisit(intValue));
- (getTypeViaVisit(boolValue));
- (getTypeViaVisit(objValue));
- (getTypeViaVisit(nodeValue));
- (getTypeViaVisit(arrValue));
- (getTypeViaVisit(uintValue));
- (getTypeViaVisit(doubleValue));
- (getTypeViaVisit(stringValue));
- }
- state.SetItemsProcessed(8 * state.iterations());
- }
- BENCHMARK_REGISTER_F(DomValueBenchmark, AzDomValueGetType_UsingVariantVisit);
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueMakeComplexObject)(benchmark::State& state)
- {
- for ([[maybe_unused]] auto _ : state)
- {
- TakeAndDiscardWithoutTimingDtor(GenerateDomBenchmarkPayload(state.range(0), state.range(1)), state);
- }
- state.SetItemsProcessed(state.range(0) * state.range(0) * state.iterations());
- }
- DOM_REGISTER_SERIALIZATION_BENCHMARK_MS(DomValueBenchmark, AzDomValueMakeComplexObject)
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueShallowCopy)(benchmark::State& state)
- {
- Value original = GenerateDomBenchmarkPayload(state.range(0), state.range(1));
- for ([[maybe_unused]] auto _ : state)
- {
- Value copy = original;
- benchmark::DoNotOptimize(copy);
- }
- state.SetItemsProcessed(state.iterations());
- }
- DOM_REGISTER_SERIALIZATION_BENCHMARK_NS(DomValueBenchmark, AzDomValueShallowCopy)
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueCopyAndMutate)(benchmark::State& state)
- {
- Value original = GenerateDomBenchmarkPayload(state.range(0), state.range(1));
- for ([[maybe_unused]] auto _ : state)
- {
- Value copy = original;
- copy["entries"]["Key0"].ArrayPushBack(Value(42));
- TakeAndDiscardWithoutTimingDtor(AZStd::move(copy), state);
- }
- state.SetItemsProcessed(state.iterations());
- }
- DOM_REGISTER_SERIALIZATION_BENCHMARK_MS(DomValueBenchmark, AzDomValueCopyAndMutate)
- BENCHMARK_DEFINE_F(DomValueBenchmark, AzDomValueDeepCopy)(benchmark::State& state)
- {
- Value original = GenerateDomBenchmarkPayload(state.range(0), state.range(1));
- for ([[maybe_unused]] auto _ : state)
- {
- Value copy = Utils::DeepCopy(original);
- TakeAndDiscardWithoutTimingDtor(AZStd::move(copy), state);
- }
- state.SetItemsProcessed(state.iterations());
- }
- DOM_REGISTER_SERIALIZATION_BENCHMARK_MS(DomValueBenchmark, AzDomValueDeepCopy)
- BENCHMARK_DEFINE_F(DomValueBenchmark, LookupMemberByName)(benchmark::State& state)
- {
- Value value(Type::Object);
- AZStd::vector<AZ::Name> keys;
- for (int64_t i = 0; i < state.range(0); ++i)
- {
- AZ::Name key(AZStd::string::format("key%" PRId64, i));
- keys.push_back(key);
- value[key] = i;
- }
- for ([[maybe_unused]] auto _ : state)
- {
- for (const AZ::Name& key : keys)
- {
- benchmark::DoNotOptimize(value[key]);
- }
- }
- state.SetItemsProcessed(state.iterations() * state.range(0));
- }
- BENCHMARK_REGISTER_F(DomValueBenchmark, LookupMemberByName)->Arg(100)->Arg(1000)->Arg(10000)->Unit(benchmark::kMillisecond);
- BENCHMARK_DEFINE_F(DomValueBenchmark, LookupMemberByString)(benchmark::State& state)
- {
- Value value(Type::Object);
- AZStd::vector<AZStd::string> keys;
- for (int64_t i = 0; i < state.range(0); ++i)
- {
- AZStd::string key(AZStd::string::format("key%" PRId64, i));
- keys.push_back(key);
- value[key] = i;
- }
- for ([[maybe_unused]] auto _ : state)
- {
- for (const AZStd::string& key : keys)
- {
- benchmark::DoNotOptimize(value[key]);
- }
- }
- state.SetItemsProcessed(state.iterations() * state.range(0));
- }
- BENCHMARK_REGISTER_F(DomValueBenchmark, LookupMemberByString)->Arg(100)->Arg(1000)->Arg(10000)->Unit(benchmark::kMillisecond);
- BENCHMARK_DEFINE_F(DomValueBenchmark, LookupMemberByStringComparison)(benchmark::State& state)
- {
- Value value(Type::Object);
- AZStd::vector<AZStd::string> keys;
- for (int64_t i = 0; i < state.range(0); ++i)
- {
- AZStd::string key(AZStd::string::format("key%" PRId64, i));
- keys.push_back(key);
- value[key] = i;
- }
- for ([[maybe_unused]] auto _ : state)
- {
- for (const AZStd::string& key : keys)
- {
- const Object::ContainerType& object = value.GetObject();
- benchmark::DoNotOptimize(AZStd::find_if(
- object.cbegin(), object.cend(),
- [&key](const Object::EntryType& entry)
- {
- return key == entry.first.GetStringView();
- }));
- }
- }
- state.SetItemsProcessed(state.iterations() * state.range(0));
- }
- BENCHMARK_REGISTER_F(DomValueBenchmark, LookupMemberByStringComparison)->Arg(100)->Arg(1000)->Arg(10000)->Unit(benchmark::kMillisecond);
- } // namespace AZ::Dom::Benchmark
|