// Copyright John Maddock 2007. // 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) #ifndef BOOST_MATH_MODF_HPP #define BOOST_MATH_MODF_HPP #ifdef _MSC_VER #pragma once #endif #include #include #include namespace boost{ namespace math{ template inline T modf(const T& v, T* ipart, const Policy& pol) { *ipart = trunc(v, pol); return v - *ipart; } template inline T modf(const T& v, T* ipart) { return modf(v, ipart, policies::policy<>()); } template inline T modf(const T& v, int* ipart, const Policy& pol) { *ipart = itrunc(v, pol); return v - *ipart; } template inline T modf(const T& v, int* ipart) { return modf(v, ipart, policies::policy<>()); } template inline T modf(const T& v, long* ipart, const Policy& pol) { *ipart = ltrunc(v, pol); return v - *ipart; } template inline T modf(const T& v, long* ipart) { return modf(v, ipart, policies::policy<>()); } #ifdef BOOST_HAS_LONG_LONG template inline T modf(const T& v, boost::long_long_type* ipart, const Policy& pol) { *ipart = lltrunc(v, pol); return v - *ipart; } template inline T modf(const T& v, boost::long_long_type* ipart) { return modf(v, ipart, policies::policy<>()); } #endif }} // namespaces #endif // BOOST_MATH_MODF_HPP