// Copyright (c) 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 // // ============================================================================ #ifndef CGAL_POLYNOMIAL_DEGREE_H #define CGAL_POLYNOMIAL_DEGREE_H #include #include namespace CGAL { namespace internal{ template struct Degree; // Polynomial musst be at least univariate ! template struct Degree > : public CGAL::cpp98::unary_function< Polynomial , int >{ private: typedef Polynomial Polynomial_d; // for univariate polynomials template int degree(const Polynomial& p, int i) const { (void) i; CGAL_assertion(i == 0); return p.degree(); } // for multivariate polynomials template int degree(const Polynomial >& p, int i) const { typedef Polynomial > Poly; if(i == (Dimension::value-1)) return p.degree(); int result = 0; for(typename Poly::const_iterator it = p.begin(); it != p.end(); it++){ result = (std::max)(result,degree(*it,i)); } return result; } public: int operator()( const Polynomial_d& p, int i = (Dimension::value-1)) const { CGAL_assertion(i < Dimension::value); CGAL_assertion(i >= 0); return this->degree(p,i); } }; } // namespace internal } //namespace CGAL #endif //CGAL_POLYNOMIAL_DEGREE_H