// Copyright (c) 2000,2001 // Utrecht University (The Netherlands), // ETH Zurich (Switzerland), // INRIA Sophia-Antipolis (France), // Max-Planck-Institute Saarbruecken (Germany), // and Tel-Aviv University (Israel). All rights reserved. // // This file is part of CGAL (www.cgal.org) // // $URL: https://github.com/CGAL/cgal/blob/v5.1/Kernel_d/include/CGAL/Kernel_d/Hyperplane_d.h $ // $Id: Hyperplane_d.h 489e853 2020-06-10T18:25:33+02:00 Laurent Rineau // SPDX-License-Identifier: LGPL-3.0-or-later OR LicenseRef-Commercial // // // Author(s) : Michael Seel #ifndef CGAL_HYPERPLANE_D_H #define CGAL_HYPERPLANE_D_H #include #include #include #include namespace CGAL { template class Hyperplane_d : public pR::Hyperplane_d_base { public: typedef CGAL::Dynamic_dimension_tag Ambient_dimension; typedef CGAL::Dynamic_dimension_tag Feature_dimension; typedef typename pR::Hyperplane_d_base Base; typedef Hyperplane_d Self; typedef pR R; typedef typename R::RT RT; typedef typename R::FT FT; typedef typename R::LA LA; Hyperplane_d(int d=0) : Base(d) {} Hyperplane_d(int a, int b, int c) : Base(a,b,c) {} Hyperplane_d(const RT& a, const RT& b, const RT& c) : Base(a,b,c) {} Hyperplane_d(int a, int b, int c, int d) : Base(a,b,c,d) {} Hyperplane_d(const RT& a, const RT& b, const RT& c, const RT& d) : Base(a,b,c,d) {} Hyperplane_d(const Point_d& p, const Direction_d& dir) : Base(p,dir) {} Hyperplane_d(const Base& p) : Base(p) {} template Hyperplane_d(int d, InputIterator first, InputIterator last) : Base (d, first, last) {} template Hyperplane_d(int d, InputIterator first, InputIterator last, const RT& D) : Base (d, first, last, D) {} template Hyperplane_d(ForwardIterator first, ForwardIterator last, const Point_d& o, Oriented_side side = ON_ORIENTED_BOUNDARY) : Base(first,last,o,side) {} Vector_d orthogonal_vector() const { return Base::orthogonal_vector(); } Direction_d orthogonal_direction() const { return Base::orthogonal_direction(); } bool operator==(const Self& w) const { return Base::operator==(w); } bool operator!=(const Self& w) const { return Base::operator!=(w); } bool operator==(const Base& w) const { return Base::operator==(w); } bool operator!=(const Base& w) const { return Base::operator!=(w); } }; } //namespace CGAL #endif //CGAL_HYPERPLANE_D_H