| 
    libMesh
    
   | 
 
#include <augment_sparsity_on_interface.h>
Public Types | |
| typedef std::unordered_map< const Elem *, const CouplingMatrix * > | map_type | 
| What elements do we care about and what variables do we care about on each element?  More... | |
Public Member Functions | |
| AugmentSparsityOnInterface (MeshBase &mesh, boundary_id_type crack_boundary_lower, boundary_id_type crack_boundary_upper) | |
| Constructor.  More... | |
| const ElementSideMap & | get_lower_to_upper () const | 
| virtual void | operator() (const MeshBase::const_element_iterator &range_begin, const MeshBase::const_element_iterator &range_end, processor_id_type p, map_type &coupled_elements) override | 
| User-defined function to augment the sparsity pattern.  More... | |
| virtual void | mesh_reinit () override | 
| Rebuild the cached _lower_to_upper map whenever our Mesh has changed.  More... | |
| virtual void | redistribute () override | 
| Update the cached _lower_to_upper map whenever our Mesh has been redistributed.  More... | |
| virtual void | operator() (const MeshBase::const_element_iterator &range_begin, const MeshBase::const_element_iterator &range_end, processor_id_type p, map_type &coupled_elements)=0 | 
| For the specified range of active elements, what other elements currently living (whether local or ghosted) on this processor need to be coupled/ghosted to accommodate them? Don't bother to return any results which already have processor_id p.  More... | |
| virtual void | dofmap_reinit () | 
| For algebraic ghosting or coupling functors we also call dofmap_reinit() later, after dofs have been distributed on the new mesh but before the functors have been queried for send_list or sparsity pattern calculations.  More... | |
| virtual void | delete_remote_elements () | 
| GhostingFunctor subclasses with relatively long-lasting caches may want to delete the no-longer-relevant parts of those caches after a redistribution is complete.  More... | |
Static Public Member Functions | |
| static std::string | get_info () | 
| Gets a string containing the reference information.  More... | |
| static void | print_info (std::ostream &out=libMesh::out) | 
Prints the reference information, by default to libMesh::out.  More... | |
| static unsigned int | n_objects () | 
| Prints the number of outstanding (created, but not yet destroyed) objects.  More... | |
| static void | enable_print_counter_info () | 
| Methods to enable/disable the reference counter output from print_info()  More... | |
| static void | disable_print_counter_info () | 
Protected Types | |
| typedef std::map< std::string, std::pair< unsigned int, unsigned int > > | Counts | 
| Data structure to log the information.  More... | |
Protected Member Functions | |
| void | increment_constructor_count (const std::string &name) | 
| Increments the construction counter.  More... | |
| void | increment_destructor_count (const std::string &name) | 
| Increments the destruction counter.  More... | |
Static Protected Attributes | |
| static Counts | _counts | 
| Actually holds the data.  More... | |
| static Threads::atomic< unsigned int > | _n_objects | 
| The number of objects.  More... | |
| static Threads::spin_mutex | _mutex | 
| Mutual exclusion object to enable thread-safe reference counting.  More... | |
| static bool | _enable_print_counter = true | 
| Flag to control whether reference count information is printed when print_info is called.  More... | |
Private Attributes | |
| MeshBase & | _mesh | 
| The Mesh we're calculating on.  More... | |
| ElementSideMap | _lower_to_upper | 
| A map from (lower element ID, side ID) to matching upper element ID.  More... | |
| ElementMap | _upper_to_lower | 
| The inverse (ignoring sides) of the above map.  More... | |
| boundary_id_type | _crack_boundary_lower | 
| Boundary IDs for the lower and upper faces of the "crack" in the mesh.  More... | |
| boundary_id_type | _crack_boundary_upper | 
| bool | _initialized | 
| Make sure we've been initialized before use.  More... | |
Definition at line 19 of file augment_sparsity_on_interface.h.
      
  | 
  protectedinherited | 
Data structure to log the information.
The log is identified by the class name.
Definition at line 117 of file reference_counter.h.
      
  | 
  inherited | 
What elements do we care about and what variables do we care about on each element?
Definition at line 171 of file ghosting_functor.h.
| AugmentSparsityOnInterface::AugmentSparsityOnInterface | ( | MeshBase & | mesh, | 
| boundary_id_type | crack_boundary_lower, | ||
| boundary_id_type | crack_boundary_upper | ||
| ) | 
Constructor.
Definition at line 9 of file augment_sparsity_on_interface.C.
References mesh_reinit().
      
  | 
  inlinevirtualinherited | 
GhostingFunctor subclasses with relatively long-lasting caches may want to delete the no-longer-relevant parts of those caches after a redistribution is complete.
Reimplemented in libMesh::PointNeighborCoupling, and libMesh::DefaultCoupling.
Definition at line 221 of file ghosting_functor.h.
      
  | 
  staticinherited | 
Definition at line 106 of file reference_counter.C.
References libMesh::ReferenceCounter::_enable_print_counter.
Referenced by libMesh::LibMeshInit::LibMeshInit().
      
  | 
  inlinevirtualinherited | 
For algebraic ghosting or coupling functors we also call dofmap_reinit() later, after dofs have been distributed on the new mesh but before the functors have been queried for send_list or sparsity pattern calculations.
Definition at line 202 of file ghosting_functor.h.
      
  | 
  staticinherited | 
Methods to enable/disable the reference counter output from print_info()
Definition at line 100 of file reference_counter.C.
References libMesh::ReferenceCounter::_enable_print_counter.
      
  | 
  staticinherited | 
Gets a string containing the reference information.
Definition at line 47 of file reference_counter.C.
References libMesh::ReferenceCounter::_counts, and libMesh::Quality::name().
Referenced by libMesh::ReferenceCounter::print_info().
| const ElementSideMap & AugmentSparsityOnInterface::get_lower_to_upper | ( | ) | const | 
Definition at line 20 of file augment_sparsity_on_interface.C.
References _initialized, _lower_to_upper, and libMesh::libmesh_assert().
Referenced by main().
      
  | 
  inlineprotectedinherited | 
Increments the construction counter.
Should be called in the constructor of any derived class that will be reference counted.
Definition at line 181 of file reference_counter.h.
References libMesh::ReferenceCounter::_counts, libMesh::Quality::name(), and libMesh::Threads::spin_mtx.
Referenced by libMesh::ReferenceCountedObject< RBParametrized >::ReferenceCountedObject().
      
  | 
  inlineprotectedinherited | 
Increments the destruction counter.
Should be called in the destructor of any derived class that will be reference counted.
Definition at line 194 of file reference_counter.h.
References libMesh::ReferenceCounter::_counts, libMesh::Quality::name(), and libMesh::Threads::spin_mtx.
Referenced by libMesh::ReferenceCountedObject< RBParametrized >::~ReferenceCountedObject().
      
  | 
  overridevirtual | 
Rebuild the cached _lower_to_upper map whenever our Mesh has changed.
Reimplemented from libMesh::GhostingFunctor.
Definition at line 26 of file augment_sparsity_on_interface.C.
References _crack_boundary_lower, _crack_boundary_upper, _initialized, _lower_to_upper, _mesh, _upper_to_lower, libMesh::MeshBase::active_element_ptr_range(), distance(), libMesh::MeshBase::get_boundary_info(), libMesh::BoundaryInfo::has_boundary_id(), libMesh::libmesh_assert(), std::norm(), libMesh::ParallelObject::processor_id(), libMesh::DofObject::processor_id(), libMesh::Real, and libMesh::TOLERANCE.
Referenced by AugmentSparsityOnInterface(), and redistribute().
      
  | 
  inlinestaticinherited | 
Prints the number of outstanding (created, but not yet destroyed) objects.
Definition at line 83 of file reference_counter.h.
References libMesh::ReferenceCounter::_n_objects.
      
  | 
  overridevirtual | 
User-defined function to augment the sparsity pattern.
Definition at line 134 of file augment_sparsity_on_interface.C.
References libMesh::as_range(), libMesh::libmesh_assert(), and libMesh::DofObject::processor_id().
      
  | 
  pure virtualinherited | 
For the specified range of active elements, what other elements currently living (whether local or ghosted) on this processor need to be coupled/ghosted to accommodate them? Don't bother to return any results which already have processor_id p.
This API is new, and we should replace "ignoring those on processor p" with "ignoring those which match a predicate functor" eventually.
Implemented in libMesh::DefaultCoupling, libMesh::PointNeighborCoupling, AugmentSparsityOnNodes, libMesh::SiblingCoupling, and libMesh::GhostPointNeighbors.
      
  | 
  staticinherited | 
Prints the reference information, by default to libMesh::out. 
Definition at line 87 of file reference_counter.C.
References libMesh::ReferenceCounter::_enable_print_counter, and libMesh::ReferenceCounter::get_info().
      
  | 
  inlineoverridevirtual | 
Update the cached _lower_to_upper map whenever our Mesh has been redistributed.
We'll be lazy and just recalculate from scratch.
Reimplemented from libMesh::GhostingFunctor.
Definition at line 82 of file augment_sparsity_on_interface.h.
References mesh_reinit().
      
  | 
  staticprotectedinherited | 
Actually holds the data.
Definition at line 122 of file reference_counter.h.
Referenced by libMesh::ReferenceCounter::get_info(), libMesh::ReferenceCounter::increment_constructor_count(), and libMesh::ReferenceCounter::increment_destructor_count().
      
  | 
  private | 
Boundary IDs for the lower and upper faces of the "crack" in the mesh.
Definition at line 43 of file augment_sparsity_on_interface.h.
Referenced by mesh_reinit().
      
  | 
  private | 
Definition at line 43 of file augment_sparsity_on_interface.h.
Referenced by mesh_reinit().
      
  | 
  staticprotectedinherited | 
Flag to control whether reference count information is printed when print_info is called.
Definition at line 141 of file reference_counter.h.
Referenced by libMesh::ReferenceCounter::disable_print_counter_info(), libMesh::ReferenceCounter::enable_print_counter_info(), and libMesh::ReferenceCounter::print_info().
      
  | 
  private | 
Make sure we've been initialized before use.
Definition at line 48 of file augment_sparsity_on_interface.h.
Referenced by get_lower_to_upper(), and mesh_reinit().
      
  | 
  private | 
A map from (lower element ID, side ID) to matching upper element ID.
Here "lower" and "upper" refer to the lower and upper (wrt +z direction) sides of the crack in our mesh.
Definition at line 33 of file augment_sparsity_on_interface.h.
Referenced by get_lower_to_upper(), and mesh_reinit().
      
  | 
  private | 
The Mesh we're calculating on.
Definition at line 26 of file augment_sparsity_on_interface.h.
Referenced by mesh_reinit().
      
  | 
  staticprotectedinherited | 
Mutual exclusion object to enable thread-safe reference counting.
Definition at line 135 of file reference_counter.h.
      
  | 
  staticprotectedinherited | 
The number of objects.
Print the reference count information when the number returns to 0.
Definition at line 130 of file reference_counter.h.
Referenced by libMesh::ReferenceCounter::n_objects(), libMesh::ReferenceCounter::ReferenceCounter(), and libMesh::ReferenceCounter::~ReferenceCounter().
      
  | 
  private | 
The inverse (ignoring sides) of the above map.
Definition at line 38 of file augment_sparsity_on_interface.h.
Referenced by mesh_reinit().
 1.8.16