File: test_cpp_dec_float_round.cpp

package info (click to toggle)
boost1.62 1.62.0%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: stretch
  • size: 686,420 kB
  • sloc: cpp: 2,609,004; xml: 972,558; ansic: 53,674; python: 32,437; sh: 8,829; asm: 3,071; cs: 2,121; makefile: 964; perl: 859; yacc: 472; php: 132; ruby: 94; f90: 55; sql: 13; csh: 6
file content (67 lines) | stat: -rw-r--r-- 1,555 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
///////////////////////////////////////////////////////////////
//  Copyright 2013 Christopher Kormanyos. Distributed under the Boost
//  Software License, Version 1.0. (See accompanying file
//  LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_
//

// Test case for ticket:
// #8065: Multiprecision rounding issue

#ifdef _MSC_VER
#  define _SCL_SECURE_NO_WARNINGS
#endif

#include <boost/detail/lightweight_test.hpp>
#include "test.hpp"
#include <boost/multiprecision/cpp_dec_float.hpp>
#include <boost/math/special_functions/round.hpp>

template<int N>
static bool round_test_imp()
{
  typedef boost::multiprecision::cpp_dec_float<N> mp_backend_type;
  typedef boost::multiprecision::number<mp_backend_type, boost::multiprecision::et_off> mp_type;

  const mp_type original_digits(1.0F);

  const mp_type scale = pow(mp_type(10), N);

  mp_type these_digits = original_digits * scale;

  these_digits  = boost::math::round(these_digits);
  these_digits /= scale;

  const std::string result = these_digits.str();

  return (result == original_digits.str());
}

template<int N>
struct round_test
{
  static bool test()
  {
    return (round_test_imp<N>() && round_test<N - 1>::test());
  }
};

template<>
struct round_test<0>
{
  static bool test()
  {
    return round_test_imp<0>();
  }
};

int main()
{
   //
   // Test cpp_dec_float rounding with boost::math::round() at various precisions:
   //
   const bool round_test_result = round_test<40>::test();

   BOOST_CHECK_EQUAL(round_test_result, true);

   return boost::report_errors();
}