104 lines
3.0 KiB
C++
104 lines
3.0 KiB
C++
// (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
|