// Copyright (c) 2006-2008 Fernando Luis Cacciola Carballal. All rights reserved. // // This file is part of CGAL (www.cgal.org); you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public License as // published by the Free Software Foundation; either version 3 of the License, // or (at your option) any later version. // // Licensees holding a valid commercial license may use this file in // accordance with the commercial license agreement provided with the software. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. // // $URL$ // $Id$ // SPDX-License-Identifier: LGPL-3.0+ // // Author(s) : Fernando Cacciola // #ifndef CGAL_CERTIFIED_NUMERIC_PREDICATES_H #define CGAL_CERTIFIED_NUMERIC_PREDICATES_H #include #include #include namespace CGAL { inline Uncertain logical_or ( Uncertain a, Uncertain b ) { return a | b ; } inline Uncertain logical_and( Uncertain a, Uncertain b ) { return a & b ; } inline Uncertain logical_or ( Uncertain a, Uncertain b, Uncertain c ) { return a | b | c ; } inline Uncertain logical_and( Uncertain a, Uncertain b, Uncertain c ) { return a & b & c ; } template inline Uncertain certified_is_zero(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(CGAL_NTS is_zero(x)) : Uncertain::indeterminate() ; } template inline Uncertain certified_is_not_zero(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(!CGAL_NTS is_zero(x)) : Uncertain::indeterminate() ; } template inline Uncertain certified_is_one(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(CGAL_NTS is_one(x) ) : Uncertain::indeterminate() ; } template inline Uncertain certified_is_negative(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(CGAL_NTS is_negative(x) ) : Uncertain::indeterminate() ; } template inline Uncertain certified_is_positive(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(CGAL_NTS is_positive(x) ) : Uncertain::indeterminate() ; } template inline Uncertain certified_sign(const NT& x) { return CGAL_NTS is_valid(x) ? make_uncertain(CGAL_NTS sign(x)) : Uncertain::indeterminate() ; } template inline Uncertain certified_compare(const NT1& n1, const NT2& n2) { return CGAL_NTS is_valid(n1) && CGAL_NTS is_valid(n2) ? make_uncertain(CGAL_NTS compare(n1,n2)) : Uncertain::indeterminate() ; } inline Uncertain certified_is_smaller( Uncertain c ) { return c == SMALLER; } inline Uncertain certified_is_equal( Uncertain c ) { return c == EQUAL; } inline Uncertain certified_is_larger( Uncertain c ) { return c == LARGER; } inline Uncertain certified_is_smaller_or_equal( Uncertain c ) { return logical_or( c == SMALLER , c == EQUAL ) ; } inline Uncertain certified_is_larger_or_equal( Uncertain c ) { return logical_or( c == LARGER , c == EQUAL ) ; } template inline Uncertain certified_is_smaller(const NT1& n1, const NT2& n2) { return certified_is_smaller(certified_compare(n1,n2)); } template inline Uncertain certified_is_equal(const NT1& n1, const NT2& n2) { return certified_is_equal(certified_compare(n1,n2)); } template inline Uncertain certified_is_larger(const NT1& n1, const NT2& n2) { return certified_is_larger(certified_compare(n1,n2)); } template inline Uncertain certified_is_smaller_or_equal(const NT1& n1, const NT2& n2) { return certified_is_smaller_or_equal(certified_compare(n1,n2)) ; } template inline Uncertain certified_is_larger_or_equal(const NT1& n1, const NT2& n2) { return certified_is_larger_or_equal(certified_compare(n1,n2)) ; } template inline Uncertain certified_sign_of_determinant2x2( const NT& a00 , const NT& a01 , const NT& a10 , const NT& a11 ) { return certified_compare(a00*a11, a10*a01) ; } } // end namespace CGAL #endif // CGAL_CERTIFIED_NUMERIC_PREDICATES_H