mirror of
				https://github.com/llvm-mirror/libcxx.git
				synced 2025-10-25 04:56:13 +08:00 
			
		
		
		
	 30b48cb1b3
			
		
	
	30b48cb1b3
	
	
	
		
			
			I've put some work into the Google Benchmark library in order to make it easier to benchmark libc++. These changes have already been upstreamed into Google Benchmark and this patch applies the changes to the in-tree version. The main improvement in the addition of a 'compare_bench.py' script which makes it very easy to compare benchmarks. For example to compare the native STL to libc++ you would run: `$ compare_bench.py ./util_smartptr.native.out ./util_smartptr.libcxx.out` And the output would look like: RUNNING: ./util_smartptr.native.out Benchmark Time CPU Iterations ---------------------------------------------------------------- BM_SharedPtrCreateDestroy 62 ns 62 ns 10937500 BM_SharedPtrIncDecRef 31 ns 31 ns 23972603 BM_WeakPtrIncDecRef 28 ns 28 ns 23648649 RUNNING: ./util_smartptr.libcxx.out Benchmark Time CPU Iterations ---------------------------------------------------------------- BM_SharedPtrCreateDestroy 46 ns 46 ns 14957265 BM_SharedPtrIncDecRef 31 ns 31 ns 22435897 BM_WeakPtrIncDecRef 34 ns 34 ns 21084337 Comparing ./util_smartptr.native.out to ./util_smartptr.libcxx.out Benchmark Time CPU ----------------------------------------------------- BM_SharedPtrCreateDestroy -0.26 -0.26 BM_SharedPtrIncDecRef +0.00 +0.00 BM_WeakPtrIncDecRef +0.21 +0.21 git-svn-id: https://llvm.org/svn/llvm-project/libcxx/trunk@278147 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			63 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #include <unordered_set>
 | |
| #include <vector>
 | |
| #include <cstdint>
 | |
| 
 | |
| #include "benchmark/benchmark_api.h"
 | |
| #include "GenerateInput.hpp"
 | |
| 
 | |
| constexpr std::size_t TestNumInputs = 1024;
 | |
| 
 | |
| template <class GenInputs>
 | |
| void BM_Sort(benchmark::State& st, GenInputs gen) {
 | |
|     using ValueType = typename decltype(gen(0))::value_type;
 | |
|     const auto in = gen(st.range(0));
 | |
|     std::vector<ValueType> inputs[5];
 | |
|     auto reset_inputs = [&]() {
 | |
|         for (auto& C : inputs) {
 | |
|             C = in;
 | |
|             benchmark::DoNotOptimize(C.data());
 | |
|         }
 | |
|     };
 | |
|     reset_inputs();
 | |
|     while (st.KeepRunning()) {
 | |
|         for (auto& I : inputs) {
 | |
|             std::sort(I.data(), I.data() + I.size());
 | |
|             benchmark::DoNotOptimize(I.data());
 | |
|         }
 | |
|         st.PauseTiming();
 | |
|         reset_inputs();
 | |
|         benchmark::ClobberMemory();
 | |
|         st.ResumeTiming();
 | |
|     }
 | |
| }
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, random_uint32,
 | |
|     getRandomIntegerInputs<uint32_t>)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, sorted_ascending_uint32,
 | |
|     getSortedIntegerInputs<uint32_t>)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, sorted_descending_uint32,
 | |
|     getReverseSortedIntegerInputs<uint32_t>)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, single_element_uint32,
 | |
|     getDuplicateIntegerInputs<uint32_t>)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, pipe_organ_uint32,
 | |
|     getPipeOrganIntegerInputs<uint32_t>)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, random_strings,
 | |
|     getRandomStringInputs)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, sorted_ascending_strings,
 | |
|     getSortedStringInputs)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, sorted_descending_strings,
 | |
|     getReverseSortedStringInputs)->Arg(TestNumInputs);
 | |
| 
 | |
| BENCHMARK_CAPTURE(BM_Sort, single_element_strings,
 | |
|     getDuplicateStringInputs)->Arg(TestNumInputs);
 | |
| 
 | |
| 
 | |
| BENCHMARK_MAIN()
 |