dust3d/thirdparty/cgal/CGAL-5.1/include/CGAL/certified_quotient_predicat...

128 lines
3.7 KiB
C++

// Copyright (c) 2006-2008 Fernando Luis Cacciola Carballal. All rights reserved.
//
// This file is part of CGAL (www.cgal.org)
//
// $URL: https://github.com/CGAL/cgal/blob/v5.1/Straight_skeleton_2/include/CGAL/certified_quotient_predicates.h $
// $Id: certified_quotient_predicates.h 0779373 2020-03-26T13:31:46+01:00 Sébastien Loriot
// SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial
//
// Author(s) : Fernando Cacciola <fernando_cacciola@ciudad.com.ar>
//
#ifndef CGAL_CERTIFIED_QUOTIENT_PREDICATES_H
#define CGAL_CERTIFIED_QUOTIENT_PREDICATES_H
#include <CGAL/certified_numeric_predicates.h>
#include <CGAL/Quotient.h>
namespace CGAL {
template <class NT>
inline Uncertain<bool> certified_quotient_is_positive(const Quotient<NT>& x)
{
Uncertain<Sign> signum = CGAL_NTS certified_sign(x.num) ;
Uncertain<Sign> sigden = CGAL_NTS certified_sign(x.den) ;
Uncertain<Sign> zero(ZERO);
return ( signum != zero ) & ( signum == sigden );
}
template <class NT>
inline Uncertain<bool> certified_quotient_is_negative(const Quotient<NT>& x)
{
Uncertain<Sign> signum = CGAL_NTS certified_sign(x.num) ;
Uncertain<Sign> sigden = CGAL_NTS certified_sign(x.den) ;
Uncertain<Sign> zero(ZERO);
return ( signum != zero ) & ( signum != sigden );
}
template <class NT>
inline Uncertain<bool> certified_quotient_is_zero(const Quotient<NT>& x)
{
return CGAL_NTS certified_is_zero(x.num) ;
}
template <class NT>
CGAL_MEDIUM_INLINE
Uncertain<Sign> certified_quotient_sign(const Quotient<NT>& x)
{
// No assumptions on the sign of den are made
return CGAL_NTS certified_sign(x.num) * CGAL_NTS certified_sign(x.den);
}
template <class NT1, class NT2>
CGAL_MEDIUM_INLINE
Uncertain<Comparison_result> certified_quotient_compare(const Quotient<NT1>& x, const Quotient<NT2>& y)
{
Uncertain<Comparison_result> r = Uncertain<Comparison_result>::indeterminate();
// No assumptions on the sign of den are made
// code assumes that SMALLER == - 1;
CGAL_precondition( SMALLER == static_cast<Comparison_result>(-1) );
Uncertain<Sign> xnumsign = CGAL_NTS certified_sign(x.num) ;
Uncertain<Sign> xdensign = CGAL_NTS certified_sign(x.den) ;
Uncertain<Sign> ynumsign = CGAL_NTS certified_sign(y.num) ;
Uncertain<Sign> ydensign = CGAL_NTS certified_sign(y.den) ;
if ( is_certain(xnumsign)
&& is_certain(xdensign)
&& is_certain(ynumsign)
&& is_certain(ydensign)
)
{
int xsign = xnumsign * xdensign ;
int ysign = ynumsign * ydensign ;
if (xsign == 0) return static_cast<Comparison_result>(-ysign);
if (ysign == 0) return static_cast<Comparison_result>(xsign);
// now (x != 0) && (y != 0)
int diff = xsign - ysign;
if (diff == 0)
{
int msign = xdensign * ydensign;
NT1 leftop = x.num * y.den * msign;
NT1 rightop = y.num * x.den * msign;
r = certified_compare(leftop, rightop);
}
else
{
r = (xsign < ysign) ? SMALLER : LARGER;
}
}
return r ;
}
template <class NT>
inline Uncertain<bool> certified_is_zero(const Quotient<NT>& n)
{
return certified_quotient_is_zero(n);
}
template <class NT>
inline Uncertain<bool> certified_is_positive(const Quotient<NT>& n)
{
return certified_quotient_is_positive(n);
}
template <class NT>
inline Uncertain<bool> certified_is_negative(const Quotient<NT>& n)
{
return certified_quotient_is_negative(n);
}
template <class NT>
inline Uncertain<Sign> certified_sign(const Quotient<NT>& n)
{
return certified_quotient_sign(n);
}
template <class NT1, class NT2>
inline Uncertain<Comparison_result> certified_compare(const Quotient<NT1>& n1, const Quotient<NT2>& n2)
{
return certified_quotient_compare(n1,n2);
}
} // end namespace CGAL
#endif // CGAL_CERTIFIED_QUOTIENT_PREDICATES_H