mirror of https://github.com/CGAL/cgal
Cleaned up; replaced 'typedef' with 'using'
This commit is contained in:
parent
7381e39e1f
commit
83d48e6bd3
|
|
@ -10,6 +10,7 @@
|
|||
//
|
||||
// Author(s) : Ron Wein <wein@post.tau.ac.il>
|
||||
// Baruch Zukerman <baruchzu@post.tau.ac.il>
|
||||
// Efi Fogel <efifogel@gmail.com>
|
||||
|
||||
#ifndef CGAL_ENVELOPE_3_H
|
||||
#define CGAL_ENVELOPE_3_H
|
||||
|
|
@ -23,100 +24,86 @@
|
|||
|
||||
namespace CGAL {
|
||||
|
||||
/*!
|
||||
* Construct the lower envelope of a given set of surfaces.
|
||||
/*! Construct the lower envelope of a given set of surfaces.
|
||||
* \param begin An iterator for the first surface.
|
||||
* \param end A past-the-end iterator for the surfaces in the range.
|
||||
* \param min_diag Output: The minimization diagram.
|
||||
* \pre The value-type of InputIterator is Traits::Surface_3.
|
||||
*/
|
||||
template <typename InputIterator, typename GeomTraits,
|
||||
class TopTraits>
|
||||
template <typename InputIterator, typename GeomTraits, typename TopolTraits>
|
||||
void lower_envelope_3(InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2<GeomTraits, TopTraits>&
|
||||
min_diagram)
|
||||
{
|
||||
typedef GeomTraits Traits_3;
|
||||
typedef typename Envelope_diagram_on_surface_2<Traits_3,
|
||||
TopTraits>::Arrangement Envelope_diagram_2;
|
||||
typedef Envelope_divide_and_conquer_3<Traits_3, Envelope_diagram_2>
|
||||
Envelope_algorithm;
|
||||
Envelope_diagram_on_surface_2<GeomTraits, TopolTraits>&
|
||||
min_diagram) {
|
||||
using Gt = GeomTraits;
|
||||
using Tt = TopolTraits;
|
||||
|
||||
using Edos_2 = Envelope_diagram_on_surface_2<Gt, Tt>;
|
||||
using Ed = typename Edos_2::Arrangement;
|
||||
using Envelope_algorithm = Envelope_divide_and_conquer_3<Gt, Ed>;
|
||||
Envelope_algorithm env_alg(min_diagram.geometry_traits(), ENVELOPE_LOWER);
|
||||
env_alg.construct_lu_envelope(begin, end, min_diagram);
|
||||
}
|
||||
|
||||
/*!
|
||||
* Construct the upper envelope of a given set of surfaces.
|
||||
/*! Construct the upper envelope of a given set of surfaces.
|
||||
* \param begin An iterator for the first surface.
|
||||
* \param end A past-the-end iterator for the surfaces in the range.
|
||||
* \param max_diag Output: The maximization diagram.
|
||||
* \pre The value-type of InputIterator is Traits::Surface_3.
|
||||
*/
|
||||
template <class InputIterator, class GeomTraits,
|
||||
class TopTraits>
|
||||
template <typename InputIterator, typename GeomTraits, typename TopolTraits>
|
||||
void upper_envelope_3(InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2<GeomTraits, TopTraits>&
|
||||
max_diagram)
|
||||
{
|
||||
typedef GeomTraits Traits_3;
|
||||
typedef typename Envelope_diagram_on_surface_2<
|
||||
Traits_3, TopTraits>::Arrangement Envelope_diagram_2;
|
||||
typedef Envelope_divide_and_conquer_3<Traits_3, Envelope_diagram_2>
|
||||
Envelope_algorithm;
|
||||
Envelope_diagram_on_surface_2<GeomTraits, TopolTraits>&
|
||||
max_diagram) {
|
||||
using Gt = GeomTraits;
|
||||
using Tt = TopolTraits;
|
||||
|
||||
using Edos = Envelope_diagram_on_surface_2<Gt, Tt>;
|
||||
using Ed = typename Edos::Arrangement;
|
||||
using Envelope_algorithm = Envelope_divide_and_conquer_3<Gt, Ed>;
|
||||
Envelope_algorithm env_alg(max_diagram.geometry_traits(), ENVELOPE_UPPER);
|
||||
env_alg.construct_lu_envelope (begin, end, max_diagram);
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
* Construct the lower envelope of a given set of xy_monotone surfaces.
|
||||
/*! Construct the lower envelope of a given set of xy_monotone surfaces.
|
||||
* \param begin An iterator for the first xy-monotone surface.
|
||||
* \param end A past-the-end iterator for the xy_monotone surfaces in the range.
|
||||
* \param min_diag Output: The minimization diagram.
|
||||
* \pre The value-type of InputIterator is GeomTraits::Surface_3.
|
||||
*/
|
||||
template <class InputIterator, class GeomTraits,
|
||||
class TopTraits>
|
||||
void
|
||||
lower_envelope_xy_monotone_3 (InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2<GeomTraits,
|
||||
TopTraits>& min_diagram)
|
||||
{
|
||||
typedef GeomTraits Traits_3;
|
||||
typedef typename Envelope_diagram_on_surface_2<
|
||||
Traits_3, TopTraits>::Arrangement Envelope_diagram_2;
|
||||
typedef Envelope_divide_and_conquer_3<Traits_3, Envelope_diagram_2>
|
||||
Envelope_algorithm;
|
||||
template <typename InputIterator, typename GeomTraits, typename TopolTraits>
|
||||
void lower_envelope_xy_monotone_3(InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2
|
||||
<GeomTraits, TopolTraits>& min_diagram) {
|
||||
using Gt = GeomTraits;
|
||||
using Tt = TopolTraits;
|
||||
|
||||
using Edos = Envelope_diagram_on_surface_2<Gt, Tt>;
|
||||
using Ed = typename Edos::Arrangement;
|
||||
using Envelope_algorithm = Envelope_divide_and_conquer_3<Gt, Ed>;
|
||||
Envelope_algorithm env_alg(min_diagram.geometry_traits(), ENVELOPE_LOWER);
|
||||
env_alg.construct_envelope_xy_monotone (begin, end, min_diagram);
|
||||
}
|
||||
|
||||
|
||||
/*!
|
||||
* Construct the upper envelope of a given set of xy_monotone surfaces.
|
||||
/*! Construct the upper envelope of a given set of xy_monotone surfaces.
|
||||
* \param begin An iterator for the first xy_monotone surface.
|
||||
* \param end A past-the-end iterator for the xy_monotone surfaces in the range.
|
||||
* \param max_diag Output: The maximization diagram.
|
||||
* \pre The value-type of InputIterator is Traits::Surface_3.
|
||||
*/
|
||||
template <class InputIterator, class GeomTraits,
|
||||
class TopTraits>
|
||||
void
|
||||
upper_envelope_xy_monotone_3 (InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2<GeomTraits,
|
||||
TopTraits>& max_diagram)
|
||||
{
|
||||
typedef GeomTraits Traits_3;
|
||||
typedef typename Envelope_diagram_on_surface_2<
|
||||
Traits_3, TopTraits>::Arrangement Envelope_diagram_2;
|
||||
typedef Envelope_divide_and_conquer_3<Traits_3, Envelope_diagram_2>
|
||||
Envelope_algorithm;
|
||||
template <typename InputIterator, typename GeomTraits, typename TopolTraits>
|
||||
void upper_envelope_xy_monotone_3(InputIterator begin, InputIterator end,
|
||||
Envelope_diagram_on_surface_2
|
||||
<GeomTraits, TopolTraits>& max_diagram) {
|
||||
using Gt = GeomTraits;
|
||||
using Tt = TopolTraits;
|
||||
|
||||
using Edos = Envelope_diagram_on_surface_2<Gt, Tt>;
|
||||
using Ed = typename Edos::Arrangement;
|
||||
using Envelope_algorithm = Envelope_divide_and_conquer_3<Gt, Ed>;
|
||||
Envelope_algorithm env_alg(max_diagram.geometry_traits(), ENVELOPE_UPPER);
|
||||
env_alg.construct_envelope_xy_monotone (begin, end, max_diagram);
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
Loading…
Reference in New Issue