annotate DEPENDENCIES/generic/include/boost/numeric/interval/detail/test_input.hpp @ 125:34e428693f5d vext

Vext -> Repoint
author Chris Cannam
date Thu, 14 Jun 2018 11:15:39 +0100
parents 2665513ce2d3
children
rev   line source
Chris@16 1 /* Boost interval/detail/test_input.hpp file
Chris@16 2 *
Chris@16 3 * Copyright 2002 Hervé Brönnimann, Guillaume Melquiond, Sylvain Pion
Chris@16 4 *
Chris@16 5 * Distributed under the Boost Software License, Version 1.0.
Chris@16 6 * (See accompanying file LICENSE_1_0.txt or
Chris@16 7 * copy at http://www.boost.org/LICENSE_1_0.txt)
Chris@16 8 */
Chris@16 9
Chris@16 10 #ifndef BOOST_NUMERIC_INTERVAL_DETAIL_TEST_INPUT_HPP
Chris@16 11 #define BOOST_NUMERIC_INTERVAL_DETAIL_TEST_INPUT_HPP
Chris@16 12
Chris@16 13 #include <boost/numeric/interval/detail/interval_prototype.hpp>
Chris@16 14
Chris@16 15 namespace boost {
Chris@16 16 namespace numeric {
Chris@16 17 namespace interval_lib {
Chris@16 18 namespace user {
Chris@16 19
Chris@16 20 template<class T> inline
Chris@16 21 bool is_zero(T const &v) { return v == static_cast<T>(0); }
Chris@16 22
Chris@16 23 template<class T> inline
Chris@16 24 bool is_neg (T const &v) { return v < static_cast<T>(0); }
Chris@16 25
Chris@16 26 template<class T> inline
Chris@16 27 bool is_pos (T const &v) { return v > static_cast<T>(0); }
Chris@16 28
Chris@16 29 } // namespace user
Chris@16 30
Chris@16 31 namespace detail {
Chris@16 32
Chris@16 33 template<class T, class Policies> inline
Chris@16 34 bool test_input(const interval<T, Policies>& x) {
Chris@16 35 typedef typename Policies::checking checking;
Chris@16 36 return checking::is_empty(x.lower(), x.upper());
Chris@16 37 }
Chris@16 38
Chris@16 39 template<class T, class Policies1, class Policies2> inline
Chris@16 40 bool test_input(const interval<T, Policies1>& x, const interval<T, Policies2>& y) {
Chris@16 41 typedef typename Policies1::checking checking1;
Chris@16 42 typedef typename Policies2::checking checking2;
Chris@16 43 return checking1::is_empty(x.lower(), x.upper()) ||
Chris@16 44 checking2::is_empty(y.lower(), y.upper());
Chris@16 45 }
Chris@16 46
Chris@16 47 template<class T, class Policies> inline
Chris@16 48 bool test_input(const T& x, const interval<T, Policies>& y) {
Chris@16 49 typedef typename Policies::checking checking;
Chris@16 50 return checking::is_nan(x) || checking::is_empty(y.lower(), y.upper());
Chris@16 51 }
Chris@16 52
Chris@16 53 template<class T, class Policies> inline
Chris@16 54 bool test_input(const interval<T, Policies>& x, const T& y) {
Chris@16 55 typedef typename Policies::checking checking;
Chris@16 56 return checking::is_empty(x.lower(), x.upper()) || checking::is_nan(y);
Chris@16 57 }
Chris@16 58
Chris@16 59 template<class T, class Policies> inline
Chris@16 60 bool test_input(const T& x) {
Chris@16 61 typedef typename Policies::checking checking;
Chris@16 62 return checking::is_nan(x);
Chris@16 63 }
Chris@16 64
Chris@16 65 template<class T, class Policies> inline
Chris@16 66 bool test_input(const T& x, const T& y) {
Chris@16 67 typedef typename Policies::checking checking;
Chris@16 68 return checking::is_nan(x) || checking::is_nan(y);
Chris@16 69 }
Chris@16 70
Chris@16 71 } // namespace detail
Chris@16 72 } // namespace interval_lib
Chris@16 73 } // namespace numeric
Chris@16 74 } // namespace boost
Chris@16 75
Chris@16 76 #endif // BOOST_NUMERIC_INTERVAL_DETAIL_TEST_INPUT_HPP