mirror of https://github.com/CGAL/cgal
84 lines
2.8 KiB
C++
84 lines
2.8 KiB
C++
// ======================================================================
|
|
//
|
|
// Copyright (c) 1997-2000 The CGAL Consortium
|
|
//
|
|
// This software and related documentation is part of an INTERNAL release
|
|
// of the Computational Geometry Algorithms Library (CGAL). It is not
|
|
// intended for general use.
|
|
//
|
|
// ----------------------------------------------------------------------
|
|
//
|
|
// release :
|
|
// release_date : 2000, September 20
|
|
//
|
|
// file : include/CGAL/Width_default_traits_3.h
|
|
// package : Width_3 (1.6)
|
|
// maintainer : Thomas Herrmann <herrmann@ifor.math.ethz.ch>
|
|
// chapter : Geometric Optimisation
|
|
//
|
|
// revision : $Revision$
|
|
// revision_date : $Date$
|
|
//
|
|
// author(s) : Thomas Herrmann, Lutz Kettner
|
|
// coordinator : ETH Zuerich (Bernd Gaertner <gaertner@inf.ethz.ch>)
|
|
//
|
|
// implementation: 3D Width of a Point Set
|
|
// ======================================================================
|
|
|
|
#ifndef CGAL_WIDTH_DEFAULT_TRAITS_3_H
|
|
#define CGAL_WIDTH_DEFAULT_TRAITS_3_H
|
|
|
|
#include <CGAL/Convex_hull_traits_3.h>
|
|
|
|
CGAL_BEGIN_NAMESPACE
|
|
|
|
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(); }
|
|
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(); }
|
|
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);
|
|
}
|
|
|
|
Point_3 make_point( const RT& hx, const RT& hy,
|
|
const RT& hz, const RT& hw) const {
|
|
return Point_3(hx,hy,hz,hw);
|
|
}
|
|
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);
|
|
}
|
|
};
|
|
|
|
CGAL_END_NAMESPACE
|
|
|
|
#endif //CGAL_WIDTH_DEFAULT_TRAITS_3_H
|