libMesh
Public Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
libMesh::VariationalMeshSmoother Class Reference

This is an implementation of Larisa Branets' smoothing algorithms. More...

#include <mesh_smoother_vsmoother.h>

Inheritance diagram for libMesh::VariationalMeshSmoother:
[legend]

Public Member Functions

 VariationalMeshSmoother (UnstructuredMesh &mesh, Real dilation_weight=0.5, const bool preserve_subdomain_boundaries=true, const Real relative_residual_tolerance=TOLERANCE *TOLERANCE, const Real absolute_residual_tolerance=TOLERANCE *TOLERANCE, const unsigned int verbosity=0)
 Constructor. More...
 
virtual ~VariationalMeshSmoother ()=default
 Destructor. More...
 
virtual void setup ()
 Setup method that creates equation systems, system, and constraints, to be called just prior to smoothing. More...
 
virtual void smooth () override
 Redefinition of the smooth function from the base class. More...
 
const MeshQualityInfoget_mesh_info () const
 Getter for the _system's _mesh_info attribute. More...
 

Protected Attributes

UnstructuredMesh_mesh
 

Private Member Functions

VariationalSmootherSystemsystem () const
 Getter for _system to protect against dangling pointers. More...
 

Private Attributes

const unsigned int _verbosity
 verbosity setting More...
 
const Real _dilation_weight
 Smoother control variables. More...
 
const bool _preserve_subdomain_boundaries
 Whether subdomain boundaries are subject to change via smoothing. More...
 
std::unique_ptr< DistributedMesh_mesh_copy
 Mesh copy to avoid multiple EquationSystems. More...
 
std::unique_ptr< EquationSystems_equation_systems
 EquationsSystems object associated with the smoother. More...
 
VariationalSmootherSystem_system
 
std::unique_ptr< VariationalSmootherConstraint_constraint
 Constraints imposed on the smoothing process. More...
 
bool _setup_called
 Attribute the keep track of whether the setup method has been called. More...
 
Real _relative_residual_tolerance
 Solver relative residual tolerance. More...
 
Real _absolute_residual_tolerance
 Solver absolute residual tolerance. More...
 

Detailed Description

This is an implementation of Larisa Branets' smoothing algorithms.

The initial implementation was done by her, the adaptation to libmesh was completed by Derek Gaston. The code was heavily refactored into something more closely resembling C++ by John Peterson in 2014. The code eventually fell out of use and stopped functioning. Patrick Behne reimplemented the smoother in 2025.

Here are the relevant publications: 1) L. Branets, G. Carey, "Extension of a mesh quality metric for elements with a curved boundary edge or surface", Journal of Computing and Information Science in Engineering, vol. 5(4), pp.302-308, 2005.

2) L. Branets, G. Carey, "A local cell quality metric and variational grid smoothing algorithm", Engineering with Computers, vol. 21, pp.19-28, 2005.

3) L. Branets, "A variational grid optimization algorithm based on a local cell quality metric", Ph.D. thesis, The University of Texas at Austin, 2005.

Notes:

1) The smoother supports tangled meshes. However, not all untangling solves converge. In other words, we are able to untangle SOME tangled meshes, but not ANY tangled mesh.

Author
Derek R. Gaston
Date
2006

Definition at line 75 of file mesh_smoother_vsmoother.h.

Constructor & Destructor Documentation

◆ VariationalMeshSmoother()

libMesh::VariationalMeshSmoother::VariationalMeshSmoother ( UnstructuredMesh mesh,
Real  dilation_weight = 0.5,
const bool  preserve_subdomain_boundaries = true,
const Real  relative_residual_tolerance = TOLERANCE * TOLERANCE,
const Real  absolute_residual_tolerance = TOLERANCE * TOLERANCE,
const unsigned int  verbosity = 0 
)

Constructor.

Parameters
meshMesh to smooth by minimizing the distortion-dilation metric.
dilation_wiehgtWeight to give the dilation metric. The distortion metric is given 1 - dilation_weight.
preserve_subdomain_boundariesWhether the smoother is to preserve or modify sobdomain boundaries.
relative_residual_toleranceSolver setting for the relative residual tolerance.
absolute_residual_toleranceSolver setting for the absolute residual tolerance.
verbositySmoother verbosity option specifying how much information is output. The verbosity levels and the corresponding information output are as follows:

verbosity = 0 : No information

verbosity > 15: Prints:

  • Solver nonlinear and linear iteration information

The VariationalSmootherSystem and VariationalSmootherConstraint classes use the same verbosity value as this VariationalMeshSmoother class. For details on what those systems print, refer to the documentation for the _verbosity attribute in each class.

Definition at line 51 of file mesh_smoother_vsmoother.C.

56  : MeshSmoother(mesh), _verbosity(verbosity),
57  _dilation_weight(dilation_weight),
58  _preserve_subdomain_boundaries(preserve_subdomain_boundaries),
59  _setup_called(false),
60  _relative_residual_tolerance(relative_residual_tolerance),
61  _absolute_residual_tolerance(absolute_residual_tolerance) {}
const unsigned int _verbosity
verbosity setting
const Real _dilation_weight
Smoother control variables.
MeshBase & mesh
bool _setup_called
Attribute the keep track of whether the setup method has been called.
MeshSmoother(UnstructuredMesh &mesh)
Constructor.
Definition: mesh_smoother.h:46
const bool _preserve_subdomain_boundaries
Whether subdomain boundaries are subject to change via smoothing.
Real _relative_residual_tolerance
Solver relative residual tolerance.
Real _absolute_residual_tolerance
Solver absolute residual tolerance.

◆ ~VariationalMeshSmoother()

virtual libMesh::VariationalMeshSmoother::~VariationalMeshSmoother ( )
virtualdefault

Destructor.

Member Function Documentation

◆ get_mesh_info()

const MeshQualityInfo & libMesh::VariationalMeshSmoother::get_mesh_info ( ) const

Getter for the _system's _mesh_info attribute.

Definition at line 184 of file mesh_smoother_vsmoother.C.

References _setup_called, _system, and libMesh::VariationalSmootherSystem::get_mesh_info().

Referenced by MeshSmootherTest::testVariationalSmoother().

185 {
186  libmesh_error_msg_if(!_setup_called, "Need to first call the setup() method of "
187  << "this VariationalMeshSmoother object, then call get_mesh_info() prior "
188  << "to calling smooth().");
189  return _system->get_mesh_info();
190 }
VariationalSmootherSystem * _system
bool _setup_called
Attribute the keep track of whether the setup method has been called.
const MeshQualityInfo & get_mesh_info()
Getter for the _mesh_info attribute.

◆ setup()

void libMesh::VariationalMeshSmoother::setup ( )
virtual

Setup method that creates equation systems, system, and constraints, to be called just prior to smoothing.

Definition at line 63 of file mesh_smoother_vsmoother.C.

References _absolute_residual_tolerance, _constraint, _dilation_weight, _equation_systems, libMesh::MeshSmoother::_mesh, _mesh_copy, _preserve_subdomain_boundaries, _relative_residual_tolerance, _setup_called, _system, _verbosity, libMesh::System::attach_constraint_object(), libMesh::MeshBase::elem_dimensions(), libMesh::VariationalSmootherSystem::get_dilation_weight(), libMesh::DiffSolver::quiet, libMesh::VariationalSmootherSystem::set_verbosity(), system(), libMesh::DifferentiableSystem::time_solver, and libMesh::DiffSolver::verbose.

Referenced by smooth(), and MeshSmootherTest::testVariationalSmoother().

64 {
65  // Check for multiple dimensions
66  if (_mesh.elem_dimensions().size() > 1)
67  libmesh_not_implemented_msg("Meshes containing elements of differing dimension are not yet supported.");
68 
69  /*
70  Ideally we'd want to update _mesh directly even if it already has an
71  EquationSystems attached and doing work on it ... and that's thwarted by the
72  problems:
73 
74  1. We can't easily tell if there's already an EquationSystems attached.
75  2. We can't attach a second EquationSystems safely (if it already has a system 0)
76  because the DoF indexing will need to be overwritten by our system.
77  3. The destructor of es won't even clean up after itself (we generally expect
78  a mesh to go unused after its EquationSystems is destroyed), much less know
79  how to restore anything from a previous EquationSystems.
80 
81  To avoid these issues, we'll just construct a new DistributedMesh _mesh_copy
82  from _mesh, then do the solve on _mesh_copy, then copy its node locations back
83  to _mesh after the solve is done. That'll be slightly less memory-efficient
84  and somewhat more CPU-efficient in the case where _mesh is serial, though
85  it'll be significantly less memory-efficient when _mesh is already distributed,
86  but either way the robustness is probably worth it.
87  */
88 
89  // Create a new mesh, EquationSystems, and System
90  _mesh_copy = std::make_unique<DistributedMesh>(_mesh);
91 
92  // If the _mesh wasn't prepared, that's fine (we'll just be moving
93  // its nodes), but we do need the copy to be prepared before our
94  // solve does things like looking at neighbors. We'll disable
95  // repartitioning and renumbering first to make sure that we can
96  // transfer our geometry changes back to the original mesh.
97  _mesh_copy->allow_renumbering(false);
98  _mesh_copy->skip_partitioning(true);
99  _mesh_copy->complete_preparation();
100 
101  _equation_systems = std::make_unique<EquationSystems>(*_mesh_copy);
102  _system =
103  &(_equation_systems->add_system<VariationalSmootherSystem>("variational_smoother_system"));
104 
105  // Set this to something > 0 to add more quadrature points than the default
106  // rule that integrates order 2 * fe_order + 1 polynomials exactly.
107  // Using higher quadrature orders has not had a significant effect on observed solutions.
108  //system()->extra_quadrature_order = 0;
109 
110  // Uncomment these to debug
111  //system()->print_element_solutions=true;
112  //system()->print_element_residuals=true;
113  //system()->print_element_jacobians=true;
114 
115  // Add boundary node and hanging node constraints
116  _constraint = std::make_unique<VariationalSmootherConstraint>(
119 
120  // Set system parameters
123 
124  // Set up solver
125  system()->time_solver = std::make_unique<SteadySolver>(*_system);
126 
127  // Uncomment this line and use -snes_test_jacobian and -snes_test_jacobian_view
128  // flags to compare the hand-coded jacobian in VariationalSmootherSystem
129  // to finite difference jacobians.
130  //system()->time_solver->diff_solver() = std::make_unique<PetscDiffSolver>(*_system);
131 
132  _equation_systems->init();
133 
134  // Solver verbosity
135  if (_verbosity > 15) {
136  DiffSolver &solver = *(system()->time_solver->diff_solver().get());
137  solver.quiet = false;
138  solver.verbose = true;
139  }
140 
141  // Solver convergence tolerances
142  system()->time_solver->diff_solver()->relative_residual_tolerance = _relative_residual_tolerance;
143  system()->time_solver->diff_solver()->absolute_residual_tolerance = _absolute_residual_tolerance;
144 
145  _setup_called = true;
146 }
const unsigned int _verbosity
verbosity setting
const Real _dilation_weight
Smoother control variables.
std::unique_ptr< EquationSystems > _equation_systems
EquationsSystems object associated with the smoother.
std::unique_ptr< TimeSolver > time_solver
A pointer to the solver object we&#39;re going to use.
Definition: diff_system.h:245
VariationalSmootherSystem * _system
UnstructuredMesh & _mesh
Definition: mesh_smoother.h:61
VariationalSmootherSystem * system() const
Getter for _system to protect against dangling pointers.
std::unique_ptr< VariationalSmootherConstraint > _constraint
Constraints imposed on the smoothing process.
void attach_constraint_object(Constraint &constrain)
Register a user object for imposing constraints.
Definition: system.C:2002
std::unique_ptr< DistributedMesh > _mesh_copy
Mesh copy to avoid multiple EquationSystems.
void set_verbosity(const unsigned int verbosity)
bool _setup_called
Attribute the keep track of whether the setup method has been called.
const std::set< unsigned char > & elem_dimensions() const
Definition: mesh_base.h:426
const bool _preserve_subdomain_boundaries
Whether subdomain boundaries are subject to change via smoothing.
Real _relative_residual_tolerance
Solver relative residual tolerance.
Real _absolute_residual_tolerance
Solver absolute residual tolerance.

◆ smooth()

void libMesh::VariationalMeshSmoother::smooth ( )
overridevirtual

Redefinition of the smooth function from the base class.

All this does is call the smooth function in this class which takes an int, using a default value of 1.

Implements libMesh::MeshSmoother.

Definition at line 148 of file mesh_smoother_vsmoother.C.

References _equation_systems, libMesh::MeshSmoother::_mesh, _mesh_copy, _setup_called, libMesh::ParallelObject::comm(), libMesh::make_range(), libMesh::MeshBase::node_ref(), setup(), libMesh::VariationalSmootherSystem::solve(), libMesh::Parallel::sync_dofobject_data_by_id(), and system().

Referenced by main(), MeshSmootherTest::testVariationalSmoother(), and MeshSmootherTest::testVariationalSmootherRegression().

149 {
150  if (!_setup_called)
151  setup();
152 
153  libmesh_try
154  {
155  system()->solve();
156  }
157 
158  libmesh_catch (ConvergenceFailure& e)
159  {
160 #ifdef LIBMESH_ENABLE_EXCEPTIONS
161  throw ConvergenceFailure("The VariationalMeshSmoother solve failed to converge.");
162 #endif
163  }
164 
165  // Update _mesh from _mesh_copy
166  for (auto * node_copy : _mesh_copy->local_node_ptr_range())
167  {
168  auto & node = _mesh.node_ref(node_copy->id());
169  for (const auto d : make_range(_mesh_copy->mesh_dimension()))
170  node(d) = (*node_copy)(d);
171  }
172 
173  SyncNodalPositions sync_object(_mesh);
174  Parallel::sync_dofobject_data_by_id (_mesh.comm(), _mesh.nodes_begin(), _mesh.nodes_end(), sync_object);
175 
176  // Release memory occupied by _mesh_copy
177  // Destruct this before _mesh_copy because it references _mesh_copy
178  _equation_systems.reset();
179  _mesh_copy.reset();
180  // We'll need to call setup again since we'll have to reconstruct _mesh_copy
181  _setup_called = false;
182 }
virtual void solve() override
Solves the system to smooth the mesh.
std::unique_ptr< EquationSystems > _equation_systems
EquationsSystems object associated with the smoother.
const Parallel::Communicator & comm() const
UnstructuredMesh & _mesh
Definition: mesh_smoother.h:61
VariationalSmootherSystem * system() const
Getter for _system to protect against dangling pointers.
std::unique_ptr< DistributedMesh > _mesh_copy
Mesh copy to avoid multiple EquationSystems.
bool _setup_called
Attribute the keep track of whether the setup method has been called.
void sync_dofobject_data_by_id(const Communicator &comm, const Iterator &range_begin, const Iterator &range_end, SyncFunctor &sync)
Request data about a range of ghost dofobjects uniquely identified by their id.
IntRange< T > make_range(T beg, T end)
The 2-parameter make_range() helper function returns an IntRange<T> when both input parameters are of...
Definition: int_range.h:173
virtual const Node & node_ref(const dof_id_type i) const
Definition: mesh_base.h:741
virtual void setup()
Setup method that creates equation systems, system, and constraints, to be called just prior to smoot...

◆ system()

VariationalSmootherSystem* libMesh::VariationalMeshSmoother::system ( ) const
inlineprivate

Getter for _system to protect against dangling pointers.

Definition at line 176 of file mesh_smoother_vsmoother.h.

References _system, and libMesh::libmesh_assert().

Referenced by setup(), and smooth().

177  {
179  return _system;
180  }
VariationalSmootherSystem * _system
libmesh_assert(ctx)

Member Data Documentation

◆ _absolute_residual_tolerance

Real libMesh::VariationalMeshSmoother::_absolute_residual_tolerance
private

Solver absolute residual tolerance.

Definition at line 201 of file mesh_smoother_vsmoother.h.

Referenced by setup().

◆ _constraint

std::unique_ptr<VariationalSmootherConstraint> libMesh::VariationalMeshSmoother::_constraint
private

Constraints imposed on the smoothing process.

Definition at line 186 of file mesh_smoother_vsmoother.h.

Referenced by setup().

◆ _dilation_weight

const Real libMesh::VariationalMeshSmoother::_dilation_weight
private

Smoother control variables.

Definition at line 142 of file mesh_smoother_vsmoother.h.

Referenced by setup().

◆ _equation_systems

std::unique_ptr<EquationSystems> libMesh::VariationalMeshSmoother::_equation_systems
private

EquationsSystems object associated with the smoother.

Definition at line 162 of file mesh_smoother_vsmoother.h.

Referenced by setup(), and smooth().

◆ _mesh

UnstructuredMesh& libMesh::MeshSmoother::_mesh
protectedinherited

◆ _mesh_copy

std::unique_ptr<DistributedMesh> libMesh::VariationalMeshSmoother::_mesh_copy
private

Mesh copy to avoid multiple EquationSystems.

Definition at line 156 of file mesh_smoother_vsmoother.h.

Referenced by setup(), and smooth().

◆ _preserve_subdomain_boundaries

const bool libMesh::VariationalMeshSmoother::_preserve_subdomain_boundaries
private

Whether subdomain boundaries are subject to change via smoothing.

Definition at line 147 of file mesh_smoother_vsmoother.h.

Referenced by setup().

◆ _relative_residual_tolerance

Real libMesh::VariationalMeshSmoother::_relative_residual_tolerance
private

Solver relative residual tolerance.

Definition at line 196 of file mesh_smoother_vsmoother.h.

Referenced by setup().

◆ _setup_called

bool libMesh::VariationalMeshSmoother::_setup_called
private

Attribute the keep track of whether the setup method has been called.

Definition at line 191 of file mesh_smoother_vsmoother.h.

Referenced by get_mesh_info(), setup(), and smooth().

◆ _system

VariationalSmootherSystem* libMesh::VariationalMeshSmoother::_system
private

Definition at line 171 of file mesh_smoother_vsmoother.h.

Referenced by get_mesh_info(), setup(), and system().

◆ _verbosity

const unsigned int libMesh::VariationalMeshSmoother::_verbosity
private

verbosity setting

Definition at line 137 of file mesh_smoother_vsmoother.h.

Referenced by setup().


The documentation for this class was generated from the following files: