dust3d/thirdparty/cgal/CGAL-5.1/include/CGAL/Width_default_traits_3.h

72 lines
2.3 KiB
C
Raw Normal View History

// Copyright (c) 1997-2000 ETH Zurich (Switzerland).
// All rights reserved.
//
// This file is part of CGAL (www.cgal.org).
//
2020-10-13 12:44:25 +00:00
// $URL: https://github.com/CGAL/cgal/blob/v5.1/Polytope_distance_d/include/CGAL/Width_default_traits_3.h $
// $Id: Width_default_traits_3.h 0779373 2020-03-26T13:31:46+01:00 Sébastien Loriot
// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-Commercial
//
//
// Author(s) : Thomas Herrmann, Lutz Kettner
#ifndef CGAL_WIDTH_DEFAULT_TRAITS_3_H
#define CGAL_WIDTH_DEFAULT_TRAITS_3_H
#include <CGAL/license/Polytope_distance_d.h>
#include <CGAL/Convex_hull_traits_3.h>
namespace CGAL {
template <class Kernel_>
class Width_default_traits_3 {
public:
typedef Kernel_ Kernel;
typedef typename Kernel::RT RT;
typedef typename Kernel::Point_3 Point_3;
typedef typename Kernel::Plane_3 Plane_3;
typedef typename Kernel::Vector_3 Vector_3;
typedef Convex_hull_traits_3<Kernel> ChullTraits;
RT get_hx( const Point_3& p) const { return p.hx(); }
RT get_hy( const Point_3& p) const { return p.hy(); }
RT get_hz( const Point_3& p) const { return p.hz(); }
RT get_hw( const Point_3& p) const { return p.hw(); }
2020-10-13 12:44:25 +00:00
void get_point_coordinates( const Point_3& p,
RT& px, RT& py, RT& pz, RT& ph) const {
px = get_hx(p);
py = get_hy(p);
pz = get_hz(p);
ph = get_hw(p);
}
RT get_a( const Plane_3& f) const { return f.a(); }
RT get_b( const Plane_3& f) const { return f.b(); }
RT get_c( const Plane_3& f) const { return f.c(); }
RT get_d( const Plane_3& f) const { return f.d(); }
2020-10-13 12:44:25 +00:00
void get_plane_coefficients( const Plane_3& f,
RT& a, RT& b, RT& c, RT& d) const {
a = get_a(f);
b = get_b(f);
c = get_c(f);
d = get_d(f);
}
2020-10-13 12:44:25 +00:00
Point_3 make_point( const RT& hx, const RT& hy,
const RT& hz, const RT& hw) const {
return Point_3(hx,hy,hz,hw);
}
2020-10-13 12:44:25 +00:00
Plane_3 make_plane( const RT& a, const RT& b,
const RT& c, const RT& d) const {
return Plane_3(a,b,c,d);
}
Vector_3 make_vector( const RT& a, const RT& b, const RT& c) const {
return Vector_3(a,b,c);
}
};
} //namespace CGAL
#endif //CGAL_WIDTH_DEFAULT_TRAITS_3_H