| //===----------------------------------------------------------------------===// |
| // |
| // 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 |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include <algorithm> |
| |
| #include "common.h" |
| |
| namespace { |
| template <class ValueType> |
| struct RangesPopHeap { |
| size_t Quantity; |
| |
| void run(benchmark::State& state) const { |
| runOpOnCopies<ValueType>( |
| state, Quantity, Order(), BatchSize::CountElements, [](auto& Copy) { |
| for (auto B = Copy.begin(), I = Copy.end(); I != B; --I) { |
| std::ranges::pop_heap(B, I); |
| } |
| }); |
| } |
| |
| std::string name() const { |
| return "BM_RangesPopHeap" + ValueType::name() + "_" + std::to_string(Quantity); |
| }; |
| }; |
| } // namespace |
| |
| int main(int argc, char** argv) { |
| benchmark::Initialize(&argc, argv); |
| if (benchmark::ReportUnrecognizedArguments(argc, argv)) |
| return 1; |
| makeCartesianProductBenchmark<RangesPopHeap, AllValueTypes>(Quantities); |
| benchmark::RunSpecifiedBenchmarks(); |
| } |