Skip to content

Commit

Permalink
Mesh 3 fix min_size when using external sizing like `Sizing_field_w…
Browse files Browse the repository at this point in the history
…ith_aabb_tree` (CGAL#8627)

## Summary of Changes

Using `min_size` with `Sizing_field_with_aabb_tree` (and probably other
sizing fields) could lead to `CGAL_error_msg()` though the scenario was
"normal".

This PR fixes this issue (and completes PR CGAL#8405)

## Release Management

* Affected package(s): Mesh_3
  • Loading branch information
sloriot authored Dec 6, 2024
2 parents b8874a2 + 47e575b commit 59657c8
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 30 deletions.
22 changes: 12 additions & 10 deletions Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h
Original file line number Diff line number Diff line change
Expand Up @@ -139,28 +139,30 @@ QStringList
Mesh_parameters::
log() const
{
auto is_valid = [](const double d)->bool { return d > 0. && d != DBL_MAX; };

QStringList res("Mesh criteria");

// doubles
if(edge_sizing > 0)
if(is_valid(edge_sizing))
res << QString("edge max size: %1").arg(edge_sizing);
if(edge_min_sizing > 0)
if(is_valid(edge_min_sizing))
res << QString("edge min size: %1").arg(edge_min_sizing);
if(edge_distance > 0)
if(is_valid(edge_distance))
res << QString("edge max distance: %1").arg(edge_distance);
if(facet_angle > 0)
if(is_valid(facet_angle))
res << QString("facet min angle: %1").arg(facet_angle);
if(facet_sizing > 0)
if(is_valid(facet_sizing))
res << QString("facet max size: %1").arg(facet_sizing);
if(facet_min_sizing > 0)
if(is_valid(facet_min_sizing))
res << QString("facet min size: %1").arg(facet_min_sizing);
if(facet_approx > 0)
if(is_valid(facet_approx))
res << QString("facet approx error: %1").arg(facet_approx);
if(tet_shape > 0)
if(is_valid(tet_shape))
res << QString("tet shape (radius-edge): %1").arg(tet_shape);
if(tet_sizing > 0)
if(is_valid(tet_sizing))
res << QString("tet max size: %1").arg(tet_sizing);
if(tet_min_sizing > 0)
if(is_valid(tet_min_sizing))
res << QString("tet min size: %1").arg(tet_min_sizing);

// booleans
Expand Down
23 changes: 3 additions & 20 deletions Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h
Original file line number Diff line number Diff line change
Expand Up @@ -456,32 +456,15 @@ class Protect_edges_sizing_field
if(dim < 0)
dim = -1 - dim;

const FT s = field(p, dim, index);
if(s < minimal_size_)
{
std::stringstream msg;
msg.precision(17);
msg << "Error: the field is smaller than minimal size ("
<< minimal_size_ << ") at ";
if(dim == 0) msg << "corner (";
else msg << "point (";
msg << p << ")";
#if CGAL_MESH_3_PROTECTION_DEBUG & 4
CGAL_error_msg(([this, str = msg.str()](){
dump_c3t3(this->c3t3_, "dump-bug");
return str.c_str();
}()));
#else // not CGAL_MESH_3_PROTECTION_DEBUG & 4
CGAL_error_msg(msg.str().c_str());
#endif
}
return s;
return field(p, dim, index);
}

/// Query the sizing field and return its value at the point `p`
FT query_size(const Bare_point& p, int dim, const Index& index) const
{
FT s = query_field(p, dim, index, size_);
if (use_minimal_size() && s < minimal_size_)
return minimal_size_;
return s;
}

Expand Down

0 comments on commit 59657c8

Please sign in to comment.