1 //===----------------------------------------------------------------------===// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 // UNSUPPORTED: c++03, c++11, c++14, c++17, c++20 10 11 #include <deque> 12 #include <string> 13 14 #include "benchmark/benchmark.h" 15 16 #include "ContainerBenchmarks.h" 17 #include "GenerateInput.h" 18 19 using namespace ContainerBenchmarks; 20 21 constexpr std::size_t TestNumInputs = 1024; 22 23 BENCHMARK_CAPTURE(BM_ConstructSize, deque_byte, std::deque<unsigned char>{})->Arg(5140480); 24 25 BENCHMARK_CAPTURE(BM_ConstructSizeValue, deque_byte, std::deque<unsigned char>{}, 0)->Arg(5140480); 26 27 BENCHMARK_CAPTURE(BM_ConstructIterIter, deque_char, std::deque<char>{}, getRandomIntegerInputs<char>) 28 ->Arg(TestNumInputs); 29 30 BENCHMARK_CAPTURE(BM_ConstructIterIter, deque_size_t, std::deque<size_t>{}, getRandomIntegerInputs<size_t>) 31 ->Arg(TestNumInputs); 32 33 BENCHMARK_CAPTURE(BM_ConstructIterIter, deque_string, std::deque<std::string>{}, getRandomStringInputs) 34 ->Arg(TestNumInputs); 35 36 BENCHMARK_CAPTURE(BM_ConstructFromRange, deque_char, std::deque<char>{}, getRandomIntegerInputs<char>) 37 ->Arg(TestNumInputs); 38 39 BENCHMARK_CAPTURE(BM_ConstructFromRange, deque_size_t, std::deque<size_t>{}, getRandomIntegerInputs<size_t>) 40 ->Arg(TestNumInputs); 41 42 BENCHMARK_CAPTURE(BM_ConstructFromRange, deque_string, std::deque<std::string>{}, getRandomStringInputs) 43 ->Arg(TestNumInputs); 44 45 BENCHMARK_CAPTURE(BM_erase_iter_in_middle, deque_int, std::deque<int>{}, getRandomIntegerInputs<int>) 46 ->Range(TestNumInputs, TestNumInputs * 10); 47 BENCHMARK_CAPTURE(BM_erase_iter_in_middle, deque_string, std::deque<std::string>{}, getRandomStringInputs) 48 ->Range(TestNumInputs, TestNumInputs * 10); 49 50 BENCHMARK_CAPTURE(BM_erase_iter_at_start, deque_int, std::deque<int>{}, getRandomIntegerInputs<int>) 51 ->Range(TestNumInputs, TestNumInputs * 10); 52 BENCHMARK_CAPTURE(BM_erase_iter_at_start, deque_string, std::deque<std::string>{}, getRandomStringInputs) 53 ->Range(TestNumInputs, TestNumInputs * 10); 54 55 BENCHMARK_MAIN(); 56