| // -*- C++ -*- |
| //===----------------------------------------------------------------------===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef BENCHMARK_VARIANT_BENCHMARKS_H |
| #define BENCHMARK_VARIANT_BENCHMARKS_H |
| |
| #include <array> |
| #include <cstddef> |
| #include <tuple> |
| #include <type_traits> |
| #include <variant> |
| |
| #include "benchmark/benchmark.h" |
| |
| #include "GenerateInput.h" |
| |
| namespace VariantBenchmarks { |
| |
| template <std::size_t I> |
| struct S { |
| static constexpr size_t v = I; |
| }; |
| |
| template <std::size_t N, std::size_t... Is> |
| static auto genVariants(std::index_sequence<Is...>) { |
| using V = std::variant<S<Is>...>; |
| using F = V (*)(); |
| static constexpr F fs[] = {[] { return V(std::in_place_index<Is>); }...}; |
| |
| std::array<V, N> result = {}; |
| for (auto& v : result) { |
| v = fs[getRandomInteger(0ul, sizeof...(Is) - 1)](); |
| } |
| |
| return result; |
| } |
| |
| template <std::size_t N, std::size_t Alts> |
| static void BM_Visit(benchmark::State& state) { |
| auto args = genVariants<N>(std::make_index_sequence<Alts>{}); |
| for (auto _ : state) { |
| benchmark::DoNotOptimize(std::apply( |
| [](auto... vs) { |
| return std::visit([](auto... is) { return (is.v + ... + 0); }, vs...); |
| }, |
| args)); |
| } |
| } |
| |
| } // end namespace VariantBenchmarks |
| |
| #endif // BENCHMARK_VARIANT_BENCHMARKS_H |