mirror of
https://github.com/boostorg/multiprecision.git
synced 2026-02-11 11:52:24 +00:00
238 lines
6.8 KiB
C++
238 lines
6.8 KiB
C++
// Copyright John Maddock 2011.
|
|
// Use, modification and distribution are subject to the
|
|
// Boost Software License, Version 1.0. (See accompanying file
|
|
// LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
// This tests two things: that cpp_dec_float_50 meets our
|
|
// conceptual requirements, and that we can instantiate
|
|
// all our distributions and special functions on this type.
|
|
//
|
|
#define BOOST_MATH_ASSERT_UNDEFINED_POLICY false
|
|
#define BOOST_MATH_INSTANTIATE_MINIMUM
|
|
|
|
#ifdef _MSC_VER
|
|
# define _SCL_SECURE_NO_WARNINGS
|
|
# pragma warning(disable:4800)
|
|
# pragma warning(disable:4512)
|
|
# pragma warning(disable:4127)
|
|
# pragma warning(disable:4512)
|
|
# pragma warning(disable:4503) // decorated name length exceeded, name was truncated
|
|
#endif
|
|
|
|
#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)
|
|
# define TEST_MPF_50
|
|
# define TEST_BACKEND
|
|
# define TEST_MPZ
|
|
# define TEST_MPFR_50
|
|
# define TEST_MPFR_6
|
|
# define TEST_MPFR_15
|
|
# define TEST_MPFR_17
|
|
# define TEST_MPFR_30
|
|
# define TEST_CPP_DEC_FLOAT
|
|
# define TEST_CPP_DEC_FLOAT_NO_ET
|
|
|
|
#ifdef _MSC_VER
|
|
#pragma message("CAUTION!!: No backend type specified so testing everything.... this will take some time!!")
|
|
#endif
|
|
#ifdef __GNUC__
|
|
#pragma warning "CAUTION!!: No backend type specified so testing everything.... this will take some time!!"
|
|
#endif
|
|
|
|
#endif
|
|
|
|
#if defined(TEST_MPF_50) || defined(TEST_MPZ)
|
|
#include <boost/multiprecision/gmp.hpp>
|
|
#endif
|
|
#ifdef TEST_BACKEND
|
|
#include <boost/multiprecision/concepts/mp_number_archetypes.hpp>
|
|
#endif
|
|
#if defined(TEST_CPP_DEC_FLOAT) || defined(TEST_CPP_DEC_FLOAT_NO_ET)
|
|
#include <boost/multiprecision/cpp_dec_float.hpp>
|
|
#endif
|
|
#if defined(TEST_MPFR_50) || defined(TEST_MPFR_6) || defined(TEST_MPFR_15) || defined(TEST_MPFR_17) || defined(TEST_MPFR_30)
|
|
#include <boost/multiprecision/mpfr.hpp>
|
|
#endif
|
|
|
|
#include <boost/math/concepts/real_type_concept.hpp>
|
|
#include "libs/math/test/compile_test/instantiate.hpp"
|
|
|
|
template <class T>
|
|
void test_extra(T)
|
|
{
|
|
T t = 1;
|
|
t = abs(t);
|
|
t = abs(t*t);
|
|
|
|
t = fabs(t);
|
|
t = fabs(t*t);
|
|
|
|
t = sqrt(t);
|
|
t = sqrt(t*t);
|
|
|
|
t = floor(t);
|
|
t = floor(t*t);
|
|
|
|
t = ceil(t);
|
|
t = ceil(t*t);
|
|
|
|
t = trunc(t);
|
|
t = trunc(t*t);
|
|
|
|
t = round(t);
|
|
t = round(t*t);
|
|
|
|
t = exp(t);
|
|
t = exp(t*t);
|
|
|
|
t = log(t);
|
|
t = log(t*t);
|
|
|
|
t = log10(t);
|
|
t = log10(t*t);
|
|
|
|
t = cos(t);
|
|
t = cos(t*t);
|
|
|
|
t = sin(t);
|
|
t = sin(t*t);
|
|
|
|
t = tan(t);
|
|
t = tan(t*t);
|
|
|
|
t = asin(t);
|
|
t = asin(t*t);
|
|
|
|
t = atan(t);
|
|
t = atan(t*t);
|
|
|
|
t = acos(t);
|
|
t = acos(t*t);
|
|
|
|
t = cosh(t);
|
|
t = cosh(t*t);
|
|
|
|
t = sinh(t);
|
|
t = sinh(t*t);
|
|
|
|
t = tanh(t);
|
|
t = tanh(t*t);
|
|
|
|
double dval = 2;
|
|
t = pow(t, t);
|
|
t = pow(t, t*t);
|
|
t = pow(t, dval);
|
|
t = pow(t*t, t);
|
|
t = pow(t*t, t*t);
|
|
t = pow(t*t, dval);
|
|
t = pow(dval, t);
|
|
t = pow(dval, t*t);
|
|
|
|
t = atan2(t, t);
|
|
t = atan2(t, t*t);
|
|
t = atan2(t, dval);
|
|
t = atan2(t*t, t);
|
|
t = atan2(t*t, t*t);
|
|
t = atan2(t*t, dval);
|
|
t = atan2(dval, t);
|
|
t = atan2(dval, t*t);
|
|
|
|
t = fmod(t, t);
|
|
t = fmod(t, t*t);
|
|
t = fmod(t, dval);
|
|
t = fmod(t*t, t);
|
|
t = fmod(t*t, t*t);
|
|
t = fmod(t*t, dval);
|
|
t = fmod(dval, t);
|
|
t = fmod(dval, t*t);
|
|
|
|
typedef typename T::backend_type backend_type;
|
|
typedef typename backend_type::exponent_type exp_type;
|
|
exp_type e = 0;
|
|
int i = 0;
|
|
|
|
t = ldexp(t, i);
|
|
t = ldexp(t*t, i);
|
|
t = ldexp(t, e);
|
|
t = ldexp(t*t, e);
|
|
|
|
t = frexp(t, &i);
|
|
t = frexp(t*t, &i);
|
|
t = frexp(t, &e);
|
|
t = frexp(t*t, &e);
|
|
}
|
|
|
|
void foo()
|
|
{
|
|
#ifdef TEST_BACKEND
|
|
instantiate(boost::multiprecision::concepts::mp_number_float_architype());
|
|
test_extra(boost::multiprecision::concepts::mp_number_float_architype());
|
|
#endif
|
|
#ifdef TEST_MPF_50
|
|
instantiate(boost::multiprecision::mpf_float_50());
|
|
test_extra(boost::multiprecision::mpf_float_50());
|
|
#endif
|
|
#ifdef TEST_MPFR_50
|
|
instantiate(boost::multiprecision::mpfr_float_50());
|
|
test_extra(boost::multiprecision::mpfr_float_50());
|
|
#endif
|
|
#ifdef TEST_MPFR_6
|
|
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> >());
|
|
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> >());
|
|
#endif
|
|
#ifdef TEST_MPFR_15
|
|
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> >());
|
|
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> >());
|
|
#endif
|
|
#ifdef TEST_MPFR_17
|
|
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> >());
|
|
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> >());
|
|
#endif
|
|
#ifdef TEST_MPFR_30
|
|
instantiate(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> >());
|
|
test_extra(boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> >());
|
|
#endif
|
|
#ifdef TEST_CPP_DEC_FLOAT
|
|
instantiate(boost::multiprecision::cpp_dec_float_50());
|
|
test_extra(boost::multiprecision::cpp_dec_float_50());
|
|
#endif
|
|
#ifdef TEST_CPP_DEC_FLOAT_NO_ET
|
|
instantiate(boost::multiprecision::mp_number<boost::multiprecision::cpp_dec_float<100>, false>());
|
|
test_extra(boost::multiprecision::mp_number<boost::multiprecision::cpp_dec_float<100>, false>());
|
|
#endif
|
|
}
|
|
|
|
int main()
|
|
{
|
|
#ifdef TEST_BACKEND
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::concepts::mp_number_float_architype>));
|
|
#endif
|
|
#ifdef TEST_MPF_50
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpf_float_50>));
|
|
#endif
|
|
#ifdef TEST_MPFR_50
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
|
|
#endif
|
|
#ifdef TEST_MPFR_6
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<6> > >));
|
|
#endif
|
|
#ifdef TEST_MPFR_15
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<15> > >));
|
|
#endif
|
|
#ifdef TEST_MPFR_17
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<17> > >));
|
|
#endif
|
|
#ifdef TEST_MPFR_30
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mp_number<boost::multiprecision::mpfr_float_backend<30> > >));
|
|
#endif
|
|
#ifdef TEST_MPFR_50
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::mpfr_float_50>));
|
|
#endif
|
|
#ifdef TEST_CPP_DEC_FLOAT
|
|
BOOST_CONCEPT_ASSERT((boost::math::concepts::RealTypeConcept<boost::multiprecision::cpp_dec_float_50>));
|
|
#endif
|
|
|
|
}
|