]>
Commit | Line | Data |
---|---|---|
b32b8144 | 1 | // Copyright Louis Dionne 2013-2017 |
7c673cae FG |
2 | // Distributed under the Boost Software License, Version 1.0. |
3 | // (See accompanying file LICENSE.md or copy at http://boost.org/LICENSE_1_0.txt) | |
4 | ||
5 | <% if input_size > 10 %> | |
6 | #define FUSION_MAX_VECTOR_SIZE <%= ((input_size + 9) / 10) * 10 %> | |
7 | <% end %> | |
8 | ||
9 | #include <boost/fusion/include/as_vector.hpp> | |
10 | #include <boost/fusion/include/make_vector.hpp> | |
11 | #include <boost/fusion/include/transform.hpp> | |
12 | ||
13 | #include "measure.hpp" | |
14 | #include <cstdlib> | |
15 | namespace fusion = boost::fusion; | |
16 | namespace hana = boost::hana; | |
17 | ||
18 | ||
19 | int main () { | |
20 | hana::benchmark::measure([] { | |
21 | long long result = 0; | |
22 | for (int iteration = 0; iteration < 1 << 10; ++iteration) { | |
23 | auto values = fusion::make_vector( | |
24 | <%= input_size.times.map { 'std::rand()' }.join(', ') %> | |
25 | ); | |
26 | ||
27 | auto transformed = fusion::as_vector(fusion::transform(values, [&](auto t) { | |
28 | return result += t; | |
29 | })); | |
30 | (void)transformed; | |
31 | } | |
32 | }); | |
33 | } |