// Copyright (c) 2003-2006 INRIA Sophia-Antipolis (France). // All rights reserved. // // This file is part of CGAL (www.cgal.org); you may redistribute it under // the terms of the Q Public License version 1.0. // See the file LICENSE.QPL distributed with CGAL. // // 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$ // // Author(s) : Monique Teillaud, Sylvain Pion, Constantinos Tsirogiannis // Partially supported by the IST Programme of the EU as a Shared-cost // RTD (FET Open) Project under Contract No IST-2000-26473 // (ECG - Effective Computational Geometry for Curves and Surfaces) // and a STREP (FET Open) Project under Contract No IST-006413 // (ACS -- Algorithms for Complex Shapes) #ifndef CGAL_ALGEBRAIC_KERNEL_CONVERTER_H #define CGAL_ALGEBRAIC_KERNEL_CONVERTER_H #include CGAL_BEGIN_NAMESPACE // TODO : // - FT converter ? template < class Al_K1, class Al_K2, class RT_converter = NT_converter, class Root_of_converter = NT_converter > class Algebraic_kernel_converter { public: typedef typename Al_K1::RT RT_1; typedef typename Al_K2::RT RT_2; typedef RT_converter RT_type_converter; typedef Root_of_converter Root_of_type_converter; typename Al_K2::Polynomial_1_2 operator () (const typename Al_K1::Polynomial_1_2 &p) const { return typename Al_K2::Polynomial_1_2(RT_converter()(p.a()), RT_converter()(p.b()), RT_converter()(p.c())); } typename Al_K2::Polynomial_for_circles_2_2 operator () (const typename Al_K1::Polynomial_for_circles_2_2 &p) const { return typename Al_K2::Polynomial_for_circles_2_2(RT_converter()(p.a()), RT_converter()(p.b()), RT_converter()(p.r_sq())); } }; CGAL_END_NAMESPACE #endif // CGAL_ALGEBRAIC_KERNEL_CONVERTER_H