test_hash.cpp 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. // Copyright John Maddock 2015.
  2. // Use, modification and distribution are subject to the
  3. // Boost Software License, Version 1.0.
  4. // (See accompanying file LICENSE_1_0.txt
  5. // or copy at http://www.boost.org/LICENSE_1_0.txt)
  6. #ifdef _MSC_VER
  7. #define _SCL_SECURE_NO_WARNINGS
  8. #endif
  9. #include <boost/multiprecision/cpp_int.hpp>
  10. #include <boost/multiprecision/cpp_bin_float.hpp>
  11. #include <boost/multiprecision/cpp_dec_float.hpp>
  12. #include <boost/multiprecision/debug_adaptor.hpp>
  13. #include <boost/multiprecision/logged_adaptor.hpp>
  14. #ifdef TEST_FLOAT128
  15. #include <boost/multiprecision/float128.hpp>
  16. #endif
  17. #ifdef TEST_GMP
  18. #include <boost/multiprecision/gmp.hpp>
  19. #endif
  20. #ifdef TEST_MPFR
  21. #include <boost/multiprecision/mpfr.hpp>
  22. #endif
  23. #ifdef TEST_MPFI
  24. #include <boost/multiprecision/mpfi.hpp>
  25. #endif
  26. #ifdef TEST_TOMMATH
  27. #include <boost/multiprecision/tommath.hpp>
  28. #endif
  29. #include <boost/functional/hash.hpp>
  30. #include "test.hpp"
  31. #include <iostream>
  32. #include <iomanip>
  33. template <class T>
  34. void test()
  35. {
  36. T val = 23;
  37. std::size_t t1 = boost::hash<T>()(val);
  38. BOOST_CHECK(t1);
  39. #ifndef BOOST_NO_CXX11_HDR_FUNCTIONAL
  40. std::size_t t2 = std::hash<T>()(val);
  41. BOOST_CHECK_EQUAL(t1, t2);
  42. #endif
  43. val = -23;
  44. std::size_t t3 = boost::hash<T>()(val);
  45. BOOST_CHECK_NE(t1, t3);
  46. #ifndef BOOST_NO_CXX11_HDR_FUNCTIONAL
  47. t2 = std::hash<T>()(val);
  48. BOOST_CHECK_EQUAL(t3, t2);
  49. #endif
  50. }
  51. int main()
  52. {
  53. test<boost::multiprecision::cpp_int>();
  54. test<boost::multiprecision::checked_int1024_t>();
  55. //test<boost::multiprecision::checked_uint512_t >();
  56. test<boost::multiprecision::number<boost::multiprecision::cpp_int_backend<64, 64, boost::multiprecision::signed_magnitude, boost::multiprecision::checked, void> > >();
  57. test<boost::multiprecision::cpp_bin_float_100>();
  58. test<boost::multiprecision::cpp_dec_float_100>();
  59. test<boost::multiprecision::cpp_rational>();
  60. test<boost::multiprecision::number<boost::multiprecision::debug_adaptor<boost::multiprecision::cpp_int::backend_type> > >();
  61. test<boost::multiprecision::number<boost::multiprecision::logged_adaptor<boost::multiprecision::cpp_int::backend_type> > >();
  62. #ifdef TEST_FLOAT128
  63. test<boost::multiprecision::float128>();
  64. #endif
  65. #ifdef TEST_GMP
  66. test<boost::multiprecision::mpz_int>();
  67. test<boost::multiprecision::mpq_rational>();
  68. test<boost::multiprecision::mpf_float>();
  69. #endif
  70. #ifdef TEST_MPFR
  71. test<boost::multiprecision::mpfr_float_50>();
  72. #endif
  73. #ifdef TEST_MPFI
  74. test<boost::multiprecision::mpfi_float_50>();
  75. #endif
  76. #ifdef TEST_TOMMATH
  77. test<boost::multiprecision::tom_int>();
  78. test<boost::multiprecision::tom_rational>();
  79. #endif
  80. return boost::report_errors();
  81. }