cgal/Mesh_3/include/CGAL/Mesh_cell_criteria_3.h

204 lines
5.2 KiB
C++

// Copyright (c) 2004-2009 INRIA Sophia-Antipolis (France).
// All rights reserved.
//
// This file is part of CGAL (www.cgal.org).
//
// $URL$
// $Id$
// SPDX-License-Identifier: GPL-3.0-or-later OR LicenseRef-Commercial
//
//
// Author(s) : Laurent RINEAU, Stephane Tayeb
#ifndef CGAL_MESH_CELL_CRITERIA_3_H
#define CGAL_MESH_CELL_CRITERIA_3_H
#include <CGAL/license/Mesh_3.h>
#include <CGAL/Mesh_3/mesh_standard_cell_criteria.h>
#include <CGAL/Mesh_3/Is_mesh_domain_field_3.h>
#include <boost/config.hpp>
# include <boost/callable_traits/is_invocable.hpp>
#include <type_traits>
namespace CGAL {
/*!
\ingroup PkgMesh3MeshClasses
The class `Mesh_cell_criteria_3` is a model of `MeshCellCriteria_3`. It provides,
for the mesh tetrahedra,
a uniform shape criterion
and a sizing field which may be a uniform or variable field.
\tparam Tr must be identical to the nested type
`Triangulation` of the instance used as model of
`MeshComplex_3InTriangulation_3`.
\cgalModels{MeshCellCriteria_3}
\sa `MeshCriteria_3`
\sa `CGAL::Mesh_criteria_3<Tr>`
\sa `CGAL::make_mesh_3()`
*/
template <typename Tr
#ifndef DOXYGEN_RUNNING
,typename Visitor_ = Mesh_3::Cell_criterion_visitor_with_radius_lower_bound<Tr>
#endif
>
class Mesh_cell_criteria_3
{
public:
/// \name Types
/// @{
/*!
Numerical type
*/
typedef typename Tr::Geom_traits::FT FT;
/// @}
typedef Visitor_ Visitor;
typedef typename Visitor::Cell_quality Cell_quality;
typedef typename Visitor::Is_cell_bad Is_cell_bad;
typedef Mesh_3::Abstract_criterion<Tr,Visitor> Abstract_criterion;
private:
typedef Mesh_3::Criteria<Tr,Visitor> Criteria;
typedef typename Tr::Cell_handle Cell_handle;
typedef Mesh_cell_criteria_3<Tr> Self;
public:
/// \name Creation
/// @{
/*!
* Returns an object to serve as default criteria for cells.
* @param radius_edge_bound is the upper bound for the radius-edge
* ratio of the tetrahedra.
* @param radius_bound is a uniform upper bound
for the circumradii of the tetrahedra in the mesh
*
* @param min_radius_bound is a uniform lower bound for the
* circumradii of the tetrahedra in the mesh.
* Only cells with a circumradius larger than that
* bound will be refined.
*
* See Section \ref introsecparam for further details.
* Note that if one parameter is set to 0, then its corresponding criterion is ignored.
*/
Mesh_cell_criteria_3(const FT& radius_edge_bound,
const FT& radius_bound,
const FT& min_radius_bound = 0.)
{
if (FT(0) != min_radius_bound)
init_min_radius(min_radius_bound);
if ( FT(0) != radius_bound )
init_radius(radius_bound);
if ( FT(0) != radius_edge_bound )
init_radius_edge(radius_edge_bound);
}
// Nb: SFINAE to avoid wrong matches with built-in numerical types
// as int.
/*!
Returns an object to serve as default criteria for facets.
@tparam SizingField must be a model of the concept
`MeshDomainField_3`.
The behavior and semantic of the arguments are the same
as above, except that the radius bound parameter is a functional
instead of a constant.
*/
template <typename Sizing_field>
Mesh_cell_criteria_3(const FT& radius_edge_bound
,const Sizing_field& radius_bound
,const FT& min_radius_bound = 0.
#ifndef DOXYGEN_RUNNING
,std::enable_if_t<
Mesh_3::Is_mesh_domain_field_3<Tr,Sizing_field>::value
>* = 0
#endif
)
{
if (FT(0) != min_radius_bound)
init_min_radius(min_radius_bound);
init_radius(radius_bound);
if ( FT(0) != radius_edge_bound )
init_radius_edge(radius_edge_bound);
}
/// @}
// Destructor
~Mesh_cell_criteria_3() { }
/**
* @brief returns whether the cell `cell` is bad or not.
* @param tr the triangulation within which `cell` lives
* @param cell the cell
*/
Is_cell_bad operator()(const Tr& tr, const Cell_handle& cell) const
{
return criteria_(tr, cell);
}
#ifndef DOXYGEN_RUNNING
void add(Abstract_criterion* criterion)
{
criteria_.add(criterion);
}
#endif
private:
void init_radius_edge(const FT& radius_edge_bound)
{
typedef Mesh_3::Cell_radius_edge_criterion<Tr,Visitor> Radius_edge_criterion;
criteria_.add(new Radius_edge_criterion(radius_edge_bound));
}
void init_radius(const FT& radius_bound)
{
typedef Mesh_3::Cell_uniform_size_criterion<Tr,Visitor> Radius_criterion;
criteria_.add(new Radius_criterion(radius_bound));
}
template < typename Sizing_field>
void init_radius(const Sizing_field& radius_bound)
{
typedef Mesh_3::Cell_variable_size_criterion<Tr,Visitor,Sizing_field>
Radius_criterion;
criteria_.add(new Radius_criterion(radius_bound));
}
void init_min_radius(const FT& min_radius_bound)
{
typedef Mesh_3::Cell_uniform_size_criterion<Tr, Visitor> Radius_criterion;
criteria_.add(new Radius_criterion(min_radius_bound, true/*lower bound*/));
}
private:
Criteria criteria_;
}; // end class Mesh_cell_criteria_3
} // end namespace CGAL
#endif // CGAL_MESH_CELL_CRITERIA_3_H