1 // Copyright John Maddock 2011.
2 // Use, modification and distribution are subject to the
3 // Boost Software License, Version 1.0. (See accompanying file
4 // LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
7 // This tests that cpp_dec_float_50 meets our
8 // conceptual requirements.
11 #define _SCL_SECURE_NO_WARNINGS
12 #pragma warning(disable : 4800)
13 #pragma warning(disable : 4512)
14 #pragma warning(disable : 4127)
15 #pragma warning(disable : 4512)
16 #pragma warning(disable : 4503) // decorated name length exceeded, name was truncated
19 #include <boost/container_hash/hash.hpp>
20 #include <libs/math/test/compile_test/poison.hpp>
22 #if !defined(TEST_MPF_50) && !defined(TEST_BACKEND) && !defined(TEST_MPZ) && !defined(TEST_CPP_DEC_FLOAT) && !defined(TEST_MPFR_50) && !defined(TEST_MPFR_6) && !defined(TEST_MPFR_15) && !defined(TEST_MPFR_17) && !defined(TEST_MPFR_30) && !defined(TEST_CPP_DEC_FLOAT_NO_ET) && !defined(TEST_LOGGED_ADAPTER) && !defined(TEST_CPP_BIN_FLOAT)
31 #define TEST_CPP_DEC_FLOAT
32 #define TEST_CPP_DEC_FLOAT_NO_ET
33 #define TEST_LOGGED_ADAPTER
34 #define TEST_CPP_BIN_FLOAT
37 #pragma message("CAUTION!!: No backend type specified so testing everything.... this will take some time!!")
40 #pragma warning "CAUTION!!: No backend type specified so testing everything.... this will take some time!!"
45 #if defined(TEST_MPF_50) || defined(TEST_MPZ)
46 #include <boost/multiprecision/gmp.hpp>
49 #include <boost/multiprecision/concepts/mp_number_archetypes.hpp>
51 #if defined(TEST_CPP_DEC_FLOAT) || defined(TEST_CPP_DEC_FLOAT_NO_ET) || defined(TEST_LOGGED_ADAPTER)
52 #include <boost/multiprecision/cpp_dec_float.hpp>
54 #if defined(TEST_CPP_BIN_FLOAT)
55 #include <boost/multiprecision/cpp_bin_float.hpp>
57 #if defined(TEST_MPFR_50) || defined(TEST_MPFR_6) || defined(TEST_MPFR_15) || defined(TEST_MPFR_17) || defined(TEST_MPFR_30)
58 #include <boost/multiprecision/mpfr.hpp>
60 #ifdef TEST_LOGGED_ADAPTER
61 #include <boost/multiprecision/logged_adaptor.hpp>
64 #include <boost/math/concepts/real_type_concept.hpp>
132 t = pow(t * t, t * t);
133 t = pow(t * t, dval);
135 t = pow(dval, t * t);
141 t = atan2(t * t, t * t);
142 t = atan2(t * t, dval);
144 t = atan2(dval, t * t);
150 t = fmod(t * t, t * t);
151 t = fmod(t * t, dval);
153 t = fmod(dval, t * t);
155 typedef typename T::backend_type backend_type;
156 typedef typename backend_type::exponent_type exp_type;
166 t = frexp(t * t, &i);
168 t = frexp(t * t, &e);
171 t = scalbn(t * t, i);
173 t = scalbn(t * t, e);
184 test_extra(boost::multiprecision::concepts::mp_number_float_architype());
187 test_extra(boost::multiprecision::mpf_float_50());
190 test_extra(boost::multiprecision::mpfr_float_50());
193 test_extra(boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<6> >());
196 test_extra(boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<15> >());
199 test_extra(boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<17> >());
202 test_extra(boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<30> >());
204 #ifdef TEST_CPP_DEC_FLOAT
205 test_extra(boost::multiprecision::cpp_dec_float_50());
207 #ifdef TEST_CPP_BIN_FLOAT
208 test_extra(boost::multiprecision::cpp_bin_float_50());
210 #ifdef TEST_CPP_DEC_FLOAT_NO_ET
211 test_extra(boost::multiprecision::number<boost::multiprecision::cpp_dec_float<100>, boost::multiprecision::et_off>());
218 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::concepts::mp_number_float_architype>));
221 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpf_float_50>));
224 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
227 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<6> > >));
230 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<15> > >));
233 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<17> > >));
236 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::number<boost::multiprecision::mpfr_float_backend<30> > >));
239 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
241 #ifdef TEST_CPP_DEC_FLOAT
242 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::cpp_dec_float_50>));
244 #ifdef TEST_CPP_BIN_FLOAT
245 BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::cpp_bin_float_50>));
247 #ifdef TEST_LOGGED_ADAPTER
248 typedef boost::multiprecision::number<boost::multiprecision::logged_adaptor<boost::multiprecision::cpp_dec_float<50> > > num_t;