// Copyright 2017-2020 Peter Dimov. // Distributed under the Boost Software License, Version 1.0. // https://www.boost.org/LICENSE_1_0.txt #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include template void test_( unsigned char const * p, int N, int M ) { Hash h; typedef std::chrono::steady_clock clock_type; clock_type::time_point t1 = clock_type::now(); for( int i = 0; i < M; ++i ) { boost::hash2::hash_append_range( h, {}, p, p + N ); } clock_type::time_point t2 = clock_type::now(); long long ms = std::chrono::duration_cast( t2 - t1 ).count(); unsigned r = boost::hash2::get_integral_result( h ); std::printf( "%s (N=%d): %u: %lld ms, %.2f MB/s\n", boost::core::type_name().c_str(), N, r, ms, 1000.0 * N * M / ms / 1048576 ); } extern unsigned char data[]; void test( int N, int M ) { using namespace boost::hash2; test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); test_( data, N, M ); puts( "--" ); } unsigned const N1 = 65536; unsigned const M1 = 65535; unsigned const N2 = 15; unsigned const M2 = M1 * N1 / N2; unsigned const N3 = 4; unsigned const M3 = M1 * N1 / N3; int main() { test( N1, M1 ); test( N2, M2 ); test( N3, M3 ); } unsigned char data[ N1 ];