// Copyright (c) 2006-2009 Max-Planck-Institute Saarbruecken (Germany). // 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) : Michael Hemmer // Ron Wein #ifndef CGAL_BIGFLOAT_INTERVAL_TRAITS_H #define CGAL_BIGFLOAT_INTERVAL_TRAITS_H #include #include namespace CGAL { // TODO: rename this into MPFI_traits ? // add a better rounding control template class Bigfloat_interval_traits; template inline long get_significant_bits(BFI bfi) { typename Bigfloat_interval_traits::Relative_precision relative_precision; return zero_in(bfi) ? -1 : (std::max)(long(0),relative_precision(bfi)); } template inline long set_precision(BFI,long prec) { typename Bigfloat_interval_traits::Set_precision set_precision; return set_precision(prec); } template inline long get_precision(BFI) { typename Bigfloat_interval_traits::Get_precision get_precision; return get_precision(); } template inline long relative_precision(const BFI& bfi) { typename Bigfloat_interval_traits::Relative_precision relative_precision; return relative_precision(bfi); } } //namespace CGAL #endif // CGAL_BIGFLOAT_INTERVAL_TRAITS_H