DUNE-GRID-GLUE (2.10)
Merge two codimension-1 surfaces that may be a positive distance apart. More...
#include <dune/grid-glue/merging/contactmerge.hh>
Public Types | |
enum | ProjectionType |
Type of the projection, closest point or outer normal projection. | |
typedef T | ctype |
the numeric type used in this interface | |
typedef Dune::FieldVector< T, dimworld > | WorldCoords |
the coordinate type used in this interface | |
typedef Dune::FieldVector< T, dim > | LocalCoords |
the coordinate type used in this interface | |
using | Grid1Coords = typename Base::Grid1Coords |
Type used for local coordinates on the grid1 side. | |
using | Grid2Coords = typename Base::Grid2Coords |
Type used for local coordinates on the grid2 side. | |
Public Member Functions | |
ContactMerge (const T allowedOverlap=T(0), std::function< WorldCoords(WorldCoords)> domainDirections=nullptr, std::function< WorldCoords(WorldCoords)> targetDirections=nullptr, ProjectionType type=OUTER_NORMAL) | |
Construct merger given overlap and possible projection directions. More... | |
ContactMerge (const T allowedOverlap, ProjectionType type) | |
Construct merger given overlap and type of the projection. More... | |
void | setSurfaceDirections (std::function< WorldCoords(WorldCoords)> domainDirections, std::function< WorldCoords(WorldCoords)> targetDirections) |
Set surface direction functions. More... | |
void | setOverlap (T overlap) |
Set the allowed overlap of the surfaces. | |
T | getOverlap () const |
Get the allowed overlap of the surfaces. | |
void | minNormalAngle (T angle) |
set minimum angle in radians between normals at x and Φ(x) | |
T | minNormalAngle () const |
get minimum angle in radians between normals at x and Φ(x) | |
void | build (const std::vector< Dune::FieldVector< double, dimworld > > &grid1_Coords, const std::vector< unsigned int > &grid1_elements, const std::vector< Dune::GeometryType > &grid1_element_types, const std::vector< Dune::FieldVector< double, dimworld > > &grid2_coords, const std::vector< unsigned int > &grid2_elements, const std::vector< Dune::GeometryType > &grid2_element_types) override |
builds the merged grid More... | |
virtual void | build (const std::vector< Dune::FieldVector< double, dimworld > > &grid1_coords, const std::vector< unsigned int > &grid1_elements, const std::vector< Dune::GeometryType > &grid1_element_types, const std::vector< Dune::FieldVector< double, dimworld > > &grid2_coords, const std::vector< unsigned int > &grid2_elements, const std::vector< Dune::GeometryType > &grid2_element_types)=0 |
builds the merged grid More... | |
unsigned int | nSimplices () const |
get the number of simplices in the merged grid The indices are then in 0..nSimplices()-1 | |
unsigned int | parents (unsigned int idx) const |
unsigned int | parent (unsigned int idx, unsigned int parId=0) const |
get index of grid-n's parent simplex for given merged grid simplex More... | |
auto | parentLocal (unsigned int idx, unsigned int corner, unsigned int parId=0) const |
get the grid-n parent's simplex local coordinates for a particular merged grid simplex corner (parent's index can be obtained via "parent<n>") More... | |
Public Attributes | |
unsigned int | counter |
Counts the number of times the computeIntersection method has been called. More... | |
Protected Types | |
using | IntersectionListProvider = SimplicialIntersectionListProvider< grid1Dim, grid2Dim > |
The computed intersections. | |
Protected Member Functions | |
void | build (const std::vector< Dune::FieldVector< T, dimworld > > &grid1Coords, const std::vector< unsigned int > &grid1Elements, const std::vector< Dune::GeometryType > &grid1ElementTypes, const std::vector< Dune::FieldVector< T, dimworld > > &grid2Coords, const std::vector< unsigned int > &grid2Elements, const std::vector< Dune::GeometryType > &grid2ElementTypes) override |
builds the merged grid More... | |
void | computeCyclicOrder (const std::vector< std::array< LocalCoords, 2 > > &polytopeCorners, const LocalCoords ¢er, std::vector< int > &ordering) const |
Order the corners of the intersection polytope in cyclic order. | |
void | setupNodalDirections (const std::vector< WorldCoords > &coords1, const std::vector< unsigned int > &elements1, const std::vector< Dune::GeometryType > &elementTypes1, const std::vector< WorldCoords > &coords2, const std::vector< unsigned int > &elements2, const std::vector< Dune::GeometryType > &elementTypes2) |
Setup the direction vectors containing the directions for each vertex. | |
void | computeOuterNormalField (const std::vector< WorldCoords > &coords, const std::vector< unsigned int > &elements, const std::vector< Dune::GeometryType > &elementTypes, std::vector< WorldCoords > &normals) |
If no direction field was specified compute the outer normal field. | |
void | removeDoubles (std::vector< std::array< LocalCoords, 2 > > &polytopeCorners) |
Remove all multiples. | |
virtual void | computeIntersections (const Dune::GeometryType &grid1ElementType, const std::vector< Dune::FieldVector< double, dimworld > > &grid1ElementCorners, std::bitset<(1<< grid1Dim)> &neighborIntersects1, unsigned int grid1Index, const Dune::GeometryType &grid2ElementType, const std::vector< Dune::FieldVector< double, dimworld > > &grid2ElementCorners, std::bitset<(1<< grid2Dim)> &neighborIntersects2, unsigned int grid2Index, std::vector< SimplicialIntersection > &intersections)=0 |
Compute the intersection between two overlapping elements. More... | |
bool | computeIntersection (unsigned int candidate0, unsigned int candidate1, const std::vector< Dune::FieldVector< double, dimworld > > &grid1Coords, const std::vector< Dune::GeometryType > &grid1_element_types, std::bitset<(1<< grid1Dim)> &neighborIntersects1, const std::vector< Dune::FieldVector< double, dimworld > > &grid2Coords, const std::vector< Dune::GeometryType > &grid2_element_types, std::bitset<(1<< grid2Dim)> &neighborIntersects2, bool insert=true) |
Compute the intersection between two overlapping elements. More... | |
Protected Attributes | |
std::vector< std::vector< unsigned int > > | grid1ElementCorners_ |
Temporary internal data. | |
Detailed Description
class Dune::GridGlue::ContactMerge< dimworld, T >
Merge two codimension-1 surfaces that may be a positive distance apart.
- Template Parameters
-
dimworld Dimension of the world coordinates. T Type used for coordinates
Constructor & Destructor Documentation
◆ ContactMerge() [1/2]
|
inline |
Construct merger given overlap and possible projection directions.
- Parameters
-
allowedOverlap Allowed overlap of the surfaces domainDirections Projection direction field for the first surface that differ from the default normal field targetDirections Projection direction field for the second surface that differ from the default normal field
◆ ContactMerge() [2/2]
|
inline |
Construct merger given overlap and type of the projection.
- Parameters
-
allowedOverlap Allowed overlap of the surfacs type Type of the projection
Member Function Documentation
◆ build() [1/3]
|
overrideinherited |
builds the merged grid
Note that the indices are used consequently throughout the whole class interface just like they are introduced here.
- Parameters
-
grid1_coords the grid1 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid1_elements array with all grid1 elements represented as corner indices into grid1_coords
grid1_element_types array with the GeometryType of the elements listed grid1_elements grid2_coords the grid2 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid2_elements just like with the grid1_elements and grid1_coords grid2_element_types array with the GeometryType of the elements listed grid2_elements
◆ build() [2/3]
|
pure virtualinherited |
builds the merged grid
Note that the indices are used consequently throughout the whole class interface just like they are introduced here.
- Parameters
-
grid1_coords the grid1 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid1_elements array with all grid1 elements represented as corner indices into grid1_coords
grid1_element_types array with the GeometryType of the elements listed grid1_elements grid2_coords the grid2 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid2_elements just like with the grid1_elements and grid1_coords grid2_element_types array with the GeometryType of the elements listed grid2_elements
◆ build() [3/3]
|
inlineoverrideprotected |
builds the merged grid
Note that the indices are used consequently throughout the whole class interface just like they are introduced here.
- Parameters
-
grid1_coords the grid1 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid1_elements array with all grid1 elements represented as corner indices into grid1_coords
grid1_element_types array with the GeometryType of the elements listed grid1_elements grid2_coords the grid2 vertices' coordinates ordered like e.g. in 3D x_0 y_0 z_0 x_1 y_1 ... y_(n-1) z_(n-1) grid2_elements just like with the grid1_elements and grid1_coords grid2_element_types array with the GeometryType of the elements listed grid2_elements
References Dune::GridGlue::StandardMerge< T, grid1Dim, grid2Dim, dimworld >::build(), and Dune::GridGlue::ContactMerge< dimworld, T >::setupNodalDirections().
◆ computeIntersection()
|
protectedinherited |
Compute the intersection between two overlapping elements.
- Returns
- true if at least one intersection point was found
◆ computeIntersections()
|
protectedpure virtualinherited |
Compute the intersection between two overlapping elements.
The result is a set of simplices stored in the vector intersections.
◆ intersectionList()
|
inlinefinalvirtualinherited |
list of intersections
- Note
- only valid after
build()
was called
Implements Dune::GridGlue::Merger< double, grid1Dim, grid2Dim, dimworld >.
◆ parent()
|
inlineinherited |
get index of grid-n's parent simplex for given merged grid simplex
- Template Parameters
-
n specify which grid
- Parameters
-
idx index of the merged grid simplex
- Returns
- index of the parent simplex
◆ parentLocal()
|
inlineinherited |
get the grid-n parent's simplex local coordinates for a particular merged grid simplex corner (parent's index can be obtained via "parent<n>")
- Template Parameters
-
n specify which grid
- Parameters
-
idx the index of the merged grid simplex corner the index of the simplex' corner
- Returns
- local coordinates in grid-n grid1
◆ parents()
|
inlineinherited |
doc me
◆ setSurfaceDirections()
|
inline |
Set surface direction functions.
The matching of the geometries offers the possibility to specify a function for the exact evaluation of domain surface normals. If no such function is specified (default) normals are interpolated.
- Parameters
-
value the new function (or nullptr to unset the function)
Member Data Documentation
◆ counter
|
inherited |
Counts the number of times the computeIntersection method has been called.
Used temporarily to speed up the implementation
The documentation for this class was generated from the following files:
- dune/grid-glue/merging/contactmerge.hh
- dune/grid-glue/merging/contactmerge.cc
