2016-07-02 05:30:54 +00:00
|
|
|
#include <unordered_set>
|
|
|
|
#include <vector>
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
#include <functional>
|
2016-07-02 05:30:54 +00:00
|
|
|
#include <cstdint>
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
#include <cstdlib>
|
|
|
|
#include <cstring>
|
2016-07-02 05:30:54 +00:00
|
|
|
|
2018-01-18 04:23:01 +00:00
|
|
|
#include "benchmark/benchmark.h"
|
2016-07-02 05:30:54 +00:00
|
|
|
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
#include "ContainerBenchmarks.hpp"
|
|
|
|
#include "GenerateInput.hpp"
|
2018-10-10 18:22:23 +00:00
|
|
|
#include "test_macros.h"
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
|
|
|
|
using namespace ContainerBenchmarks;
|
|
|
|
|
|
|
|
constexpr std::size_t TestNumInputs = 1024;
|
|
|
|
|
|
|
|
template <class _Size>
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
_Size loadword(const void* __p) {
|
|
|
|
_Size __r;
|
|
|
|
std::memcpy(&__r, __p, sizeof(__r));
|
|
|
|
return __r;
|
2016-07-02 05:30:54 +00:00
|
|
|
}
|
|
|
|
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t rotate_by_at_least_1(std::size_t __val, int __shift) {
|
|
|
|
return (__val >> __shift) | (__val << (64 - __shift));
|
|
|
|
}
|
|
|
|
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t hash_len_16(std::size_t __u, std::size_t __v) {
|
|
|
|
const std::size_t __mul = 0x9ddfea08eb382d69ULL;
|
|
|
|
std::size_t __a = (__u ^ __v) * __mul;
|
|
|
|
__a ^= (__a >> 47);
|
|
|
|
std::size_t __b = (__v ^ __a) * __mul;
|
|
|
|
__b ^= (__b >> 47);
|
|
|
|
__b *= __mul;
|
|
|
|
return __b;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
template <std::size_t _Len>
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t hash_len_0_to_8(const char* __s) {
|
|
|
|
static_assert(_Len == 4 || _Len == 8, "");
|
|
|
|
const uint64_t __a = loadword<uint32_t>(__s);
|
|
|
|
const uint64_t __b = loadword<uint32_t>(__s + _Len - 4);
|
|
|
|
return hash_len_16(_Len + (__a << 3), __b);
|
2016-07-02 05:30:54 +00:00
|
|
|
}
|
|
|
|
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
struct UInt32Hash {
|
|
|
|
UInt32Hash() = default;
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t operator()(uint32_t data) const {
|
|
|
|
return hash_len_0_to_8<4>(reinterpret_cast<const char*>(&data));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct UInt64Hash {
|
|
|
|
UInt64Hash() = default;
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t operator()(uint64_t data) const {
|
|
|
|
return hash_len_0_to_8<8>(reinterpret_cast<const char*>(&data));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct UInt128Hash {
|
|
|
|
UInt128Hash() = default;
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t operator()(__uint128_t data) const {
|
|
|
|
const __uint128_t __mask = static_cast<std::size_t>(-1);
|
|
|
|
const std::size_t __a = (std::size_t)(data & __mask);
|
|
|
|
const std::size_t __b = (std::size_t)((data & (__mask << 64)) >> 64);
|
|
|
|
return hash_len_16(__a, rotate_by_at_least_1(__b + 16, 16)) ^ __b;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct UInt32Hash2 {
|
|
|
|
UInt32Hash2() = default;
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t operator()(uint32_t data) const {
|
|
|
|
const uint32_t __m = 0x5bd1e995;
|
|
|
|
const uint32_t __r = 24;
|
|
|
|
uint32_t __h = 4;
|
|
|
|
uint32_t __k = data;
|
|
|
|
__k *= __m;
|
|
|
|
__k ^= __k >> __r;
|
|
|
|
__k *= __m;
|
|
|
|
__h *= __m;
|
|
|
|
__h ^= __k;
|
|
|
|
__h ^= __h >> 13;
|
|
|
|
__h *= __m;
|
|
|
|
__h ^= __h >> 15;
|
|
|
|
return __h;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct UInt64Hash2 {
|
|
|
|
UInt64Hash2() = default;
|
2018-10-10 18:22:23 +00:00
|
|
|
inline TEST_ALWAYS_INLINE
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
std::size_t operator()(uint64_t data) const {
|
|
|
|
return hash_len_0_to_8<8>(reinterpret_cast<const char*>(&data));
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
// BM_Hash
|
|
|
|
// ---------------------------------------------------------------------------//
|
|
|
|
|
|
|
|
template <class HashFn, class GenInputs>
|
|
|
|
void BM_Hash(benchmark::State& st, HashFn fn, GenInputs gen) {
|
2016-08-09 18:56:48 +00:00
|
|
|
auto in = gen(st.range(0));
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
const auto end = in.data() + in.size();
|
|
|
|
std::size_t last_hash = 0;
|
|
|
|
benchmark::DoNotOptimize(&last_hash);
|
2016-07-02 05:30:54 +00:00
|
|
|
while (st.KeepRunning()) {
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
for (auto it = in.data(); it != end; ++it) {
|
|
|
|
benchmark::DoNotOptimize(last_hash += fn(*it));
|
2016-07-02 05:30:54 +00:00
|
|
|
}
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
benchmark::ClobberMemory();
|
2016-07-02 05:30:54 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
[libcxx] Add support for benchmark tests using Google Benchmark.
Summary:
This patch does the following:
1. Checks in a copy of the Google Benchmark library into the libc++ repo under `utils/google-benchmark`.
2. Teaches libc++ how to build Google Benchmark against both (A) in-tree libc++ and (B) the platforms native STL.
3. Allows performance benchmarks to be built as part of the libc++ build.
Building the benchmarks (and Google Benchmark) is off by default. It must be enabled using the CMake option `-DLIBCXX_INCLUDE_BENCHMARKS=ON`. When this option is enabled the tests under `libcxx/benchmarks` can be built using the `libcxx-benchmarks` target.
On Linux platforms where libstdc++ is the default STL the CMake option `-DLIBCXX_BUILD_BENCHMARKS_NATIVE_STDLIB=ON` can be used to build each benchmark test against libstdc++ as well. This is useful for comparing performance between standard libraries.
Support for benchmarks is currently very minimal. They must be manually run by the user and there is no mechanism for detecting performance regressions.
Known Issues:
* `-DLIBCXX_INCLUDE_BENCHMARKS=ON` is only supported for Clang, and not GCC, since the `-stdlib=libc++` option is needed to build Google Benchmark.
Reviewers: danalbert, dberlin, chandlerc, mclow.lists, jroelofs
Subscribers: chandlerc, dberlin, tberghammer, danalbert, srhines, hfinkel
Differential Revision: https://reviews.llvm.org/D22240
llvm-svn: 276049
2016-07-19 23:07:03 +00:00
|
|
|
BENCHMARK_CAPTURE(BM_Hash,
|
|
|
|
uint32_random_std_hash,
|
|
|
|
std::hash<uint32_t>{},
|
|
|
|
getRandomIntegerInputs<uint32_t>) -> Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_Hash,
|
|
|
|
uint32_random_custom_hash,
|
|
|
|
UInt32Hash{},
|
|
|
|
getRandomIntegerInputs<uint32_t>) -> Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_Hash,
|
|
|
|
uint32_top_std_hash,
|
|
|
|
std::hash<uint32_t>{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint32_t>) -> Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_Hash,
|
|
|
|
uint32_top_custom_hash,
|
|
|
|
UInt32Hash{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint32_t>) -> Arg(TestNumInputs);
|
|
|
|
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
// BM_InsertValue
|
|
|
|
// ---------------------------------------------------------------------------//
|
|
|
|
|
|
|
|
|
|
|
|
// Sorted Assending //
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValue,
|
|
|
|
unordered_set_uint32,
|
|
|
|
std::unordered_set<uint32_t>{},
|
|
|
|
getRandomIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValue,
|
|
|
|
unordered_set_uint32_sorted,
|
|
|
|
std::unordered_set<uint32_t>{},
|
|
|
|
getSortedIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
// Top Bytes //
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValue,
|
|
|
|
unordered_set_top_bits_uint32,
|
|
|
|
std::unordered_set<uint32_t>{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValueRehash,
|
|
|
|
unordered_set_top_bits_uint32,
|
|
|
|
std::unordered_set<uint32_t, UInt32Hash>{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
// String //
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValue,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertValueRehash,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
//----------------------------------------------------------------------------//
|
|
|
|
// BM_Find
|
|
|
|
// ---------------------------------------------------------------------------//
|
|
|
|
|
|
|
|
// Random //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_random_uint64,
|
|
|
|
std::unordered_set<uint64_t>{},
|
|
|
|
getRandomIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_random_uint64,
|
|
|
|
std::unordered_set<uint64_t, UInt64Hash>{},
|
|
|
|
getRandomIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
// Sorted //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_sorted_uint64,
|
|
|
|
std::unordered_set<uint64_t>{},
|
|
|
|
getSortedIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_sorted_uint64,
|
|
|
|
std::unordered_set<uint64_t, UInt64Hash>{},
|
|
|
|
getSortedIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
|
|
|
|
// Sorted //
|
|
|
|
#if 1
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_sorted_uint128,
|
|
|
|
std::unordered_set<__uint128_t, UInt128Hash>{},
|
|
|
|
getSortedTopBitsIntegerInputs<__uint128_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_sorted_uint128,
|
|
|
|
std::unordered_set<__uint128_t, UInt128Hash>{},
|
|
|
|
getSortedTopBitsIntegerInputs<__uint128_t>)->Arg(TestNumInputs);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// Sorted //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_sorted_uint32,
|
|
|
|
std::unordered_set<uint32_t>{},
|
|
|
|
getSortedIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_sorted_uint32,
|
|
|
|
std::unordered_set<uint32_t, UInt32Hash2>{},
|
|
|
|
getSortedIntegerInputs<uint32_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
// Sorted Ascending //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_sorted_large_uint64,
|
|
|
|
std::unordered_set<uint64_t>{},
|
|
|
|
getSortedLargeIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_sorted_large_uint64,
|
|
|
|
std::unordered_set<uint64_t, UInt64Hash>{},
|
|
|
|
getSortedLargeIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
|
|
|
|
// Top Bits //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_top_bits_uint64,
|
|
|
|
std::unordered_set<uint64_t>{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_top_bits_uint64,
|
|
|
|
std::unordered_set<uint64_t, UInt64Hash>{},
|
|
|
|
getSortedTopBitsIntegerInputs<uint64_t>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
// String //
|
|
|
|
BENCHMARK_CAPTURE(BM_Find,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_FindRehash,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
2016-07-02 05:30:54 +00:00
|
|
|
|
2016-07-24 06:22:25 +00:00
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertDuplicate,
|
|
|
|
unordered_set_int,
|
|
|
|
std::unordered_set<int>{},
|
|
|
|
getRandomIntegerInputs<int>)->Arg(TestNumInputs);
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertDuplicate,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_EmplaceDuplicate,
|
|
|
|
unordered_set_int,
|
|
|
|
std::unordered_set<int>{},
|
|
|
|
getRandomIntegerInputs<int>)->Arg(TestNumInputs);
|
|
|
|
BENCHMARK_CAPTURE(BM_EmplaceDuplicate,
|
|
|
|
unordered_set_string,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertDuplicate,
|
|
|
|
unordered_set_int_insert_arg,
|
|
|
|
std::unordered_set<int>{},
|
|
|
|
getRandomIntegerInputs<int>)->Arg(TestNumInputs);
|
|
|
|
BENCHMARK_CAPTURE(BM_InsertDuplicate,
|
|
|
|
unordered_set_string_insert_arg,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_EmplaceDuplicate,
|
|
|
|
unordered_set_int_insert_arg,
|
|
|
|
std::unordered_set<int>{},
|
|
|
|
getRandomIntegerInputs<unsigned>)->Arg(TestNumInputs);
|
|
|
|
|
|
|
|
BENCHMARK_CAPTURE(BM_EmplaceDuplicate,
|
|
|
|
unordered_set_string_arg,
|
|
|
|
std::unordered_set<std::string>{},
|
|
|
|
getRandomCStringInputs)->Arg(TestNumInputs);
|
|
|
|
|
2018-01-18 04:23:01 +00:00
|
|
|
BENCHMARK_MAIN();
|