liuxiaolong
2021-07-20 58d904a328c0d849769b483e901a0be9426b8209
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
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
//  (C) Copyright Gennadiy Rozental 2001.
//  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_0.txt)
 
//  See http://www.boost.org/libs/test for the library home page.
//
//  File        : $RCSfile$
//
//  Version     : $Revision: 74248 $
//
//  Description : FPC tools tolerance holder
// ***************************************************************************
 
#ifndef BOOST_TEST_TOOLS_FPC_TOLERANCE_HPP_121612GER
#define BOOST_TEST_TOOLS_FPC_TOLERANCE_HPP_121612GER
 
// Boost Test
#include <boost/test/tree/decorator.hpp>
#include <boost/test/tools/floating_point_comparison.hpp>
 
#include <boost/test/detail/suppress_warnings.hpp>
 
//____________________________________________________________________________//
 
namespace boost {
namespace test_tools {
 
namespace fpc = math::fpc;
 
// ************************************************************************** //
// **************     floating point comparison tolerance      ************** //
// ************************************************************************** //
 
template<typename FPT>
inline FPT&
fpc_tolerance()
{
    static FPT s_value = 0;
    return s_value;
}
 
//____________________________________________________________________________//
 
template<typename FPT>
struct local_fpc_tolerance {
    local_fpc_tolerance( FPT fraction_tolerance ) : m_old_tolerance( fpc_tolerance<FPT>() )
    {
        fpc_tolerance<FPT>() = fraction_tolerance;
    }
 
    ~local_fpc_tolerance()
    {
        if( m_old_tolerance != (FPT)-1 )
            fpc_tolerance<FPT>() = m_old_tolerance;
    }
 
private:
    // Data members
    FPT         m_old_tolerance;
};
 
//____________________________________________________________________________//
 
} // namespace test_tools
 
// ************************************************************************** //
// **************             decorator::tolerance             ************** //
// ************************************************************************** //
 
namespace unit_test {
namespace decorator {
 
template<typename FPT>
inline fixture_t
tolerance( FPT v )
{
    return fixture_t( test_unit_fixture_ptr(
        new unit_test::class_based_fixture<test_tools::local_fpc_tolerance<FPT>,FPT>( v ) ) );
}
 
//____________________________________________________________________________//
 
template<typename FPT>
inline fixture_t
tolerance( test_tools::fpc::percent_tolerance_t<FPT> v )
{
    return fixture_t( test_unit_fixture_ptr(
        new unit_test::class_based_fixture<test_tools::local_fpc_tolerance<FPT>,FPT>( boost::math::fpc::fpc_detail::fraction_tolerance<FPT>( v ) ) ) );
}
 
//____________________________________________________________________________//
 
} // namespace decorator
 
using decorator::tolerance;
 
} // namespace unit_test
} // namespace boost
 
#include <boost/test/detail/enable_warnings.hpp>
 
#endif // BOOST_TEST_TOOLS_FPC_TOLERANCE_HPP_121612GER