From 5a717379e71c56b1f3f45d1bd50093ca2a303c06 Mon Sep 17 00:00:00 2001 From: Jane Tournois Date: Tue, 26 Nov 2024 17:37:10 +0100 Subject: [PATCH 1/3] improve display of parameters in demo log --- Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h | 22 +++++++++++---------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h b/Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h index ec38a369ea01..37d59c7e0a54 100644 --- a/Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h +++ b/Lab/demo/Lab/Plugins/Mesh_3/Mesh_function.h @@ -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 From 7e1f24e5fbedf26a5ade1752562f4e7fe87a3ff9 Mon Sep 17 00:00:00 2001 From: Jane Tournois Date: Tue, 26 Nov 2024 18:08:10 +0100 Subject: [PATCH 2/3] when sizing field is smaller than min_size, return min_size! --- .../CGAL/Mesh_3/Protect_edges_sizing_field.h | 25 +++---------------- 1 file changed, 4 insertions(+), 21 deletions(-) diff --git a/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h b/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h index e84e7dd933fe..241f99033dee 100644 --- a/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h +++ b/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h @@ -455,33 +455,16 @@ class Protect_edges_sizing_field // negative value (marker for special balls). 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; + else + 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; } From 47e575b77905846047ee787620bc5392054218b6 Mon Sep 17 00:00:00 2001 From: Jane Tournois Date: Fri, 29 Nov 2024 10:33:11 +0100 Subject: [PATCH 3/3] remove extra "else" --- Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h b/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h index 241f99033dee..1f33f2d70fb3 100644 --- a/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h +++ b/Mesh_3/include/CGAL/Mesh_3/Protect_edges_sizing_field.h @@ -455,8 +455,8 @@ class Protect_edges_sizing_field // negative value (marker for special balls). if(dim < 0) dim = -1 - dim; - else - return field(p, dim, index); + + return field(p, dim, index); } /// Query the sizing field and return its value at the point `p`