G+Smo
25.01.0
Geometry + Simulation Modules
|
This class provides a Hierarchical Box (gsHBox)
A gsHBox is a 'smart' object that represents an element or multiple elements in a mesh. It closely relates to the element definition used in gsHTensorBasis::asElements. Using the gsHBox as an element, it can provide its parent and its children on other levels, its support extensions and its refinement neighborhoods. Furthermore, the gsHBox has functions to check if it is equal to or contained in other gsHBoxes.
The gsHBoxContainer is a container of gsHBoxes, that can be used to perform operations on multiple gsHBoxes. Furthermore, it is an object that can be used to store neighborhoods. Other containers are the gsHBox::Container or the gsHBoxSortedContainer.
Operations such as domain intersections, unions, or the sorting of gsHBoxContainers are provided in gsHBoxUtils.
d | Domain dimension |
T | Real type |
Public Types | |
typedef memory::shared_ptr< gsHBox > | Ptr |
Shared pointer for gsHTensorBasis. | |
typedef memory::unique_ptr< gsHBox > | uPtr |
Unique pointer for gsHTensorBasis. | |
Public Member Functions | |
void | clean (Container &container) const |
Cleans the container from bad elements (see good()) | |
void | computeCenter () const |
Computes the center of this. | |
void | computeCoordinates () const |
Computes the parametric coordinates of this. | |
bool | contains (const gsHBox< d, T > &other) const |
Checks if the other cell is contains in this cell. | |
T | error () const |
Gets the error stored in the object. | |
gsHBox< d, T > | getAncestor (index_t k) const |
Gets the ancestor of the object on level k. | |
T | getCellSize () const |
Return the diagonal of the element. | |
const gsMatrix< T > & | getCenter () const |
Gets the center of the box. | |
Container | getCextension (index_t m) |
Gets the Coarsening extension, which is the coarsening neighborhood before checking for active elements. | |
Container | getChildren () const |
Gets the children of the object. | |
Container | getCneighborhood (index_t m) |
Gets the Coarsening neighborhood. | |
const gsMatrix< T > & | getCoordinates () const |
Gets the coordinates of the box (first column lower corner, second column higher corner). | |
Container | getDescendants (index_t k) const |
Gets the descendants of the object on level k. | |
Container | getHneighborhood (index_t m) |
Gets the H-neighborhood. | |
T | getMaxCellLength () const |
Return the length of the largest edge of the element. | |
T | getMinCellLength () const |
Return the length of the smallest edge of the element. | |
Container | getMultiLevelSupportExtension (index_t k) |
Gets the multi-level support extension. | |
template<gsHNeighborhood _mode> | |
gsHBox< d, T >::Container | getNeighborhood (index_t m) |
Gets the neighborhood. | |
Container | getNeighborhood (index_t m) |
Gets the refinement neighborhood. Returns either the H- or T-neighborhood, depending on the underlying basis. | |
gsHBox< d, T > | getParent () const |
Gets the parent of the object. | |
Container | getSupportExtension () |
Gets the support extension. | |
Container | getTneighborhood (index_t m) |
Gets the T-neighborhood. | |
bool | good () const |
Checks if the box has positive indices. | |
gsHBox () | |
Default constructor. | |
gsHBox (const gsAABB< d, index_t > &box, const gsHTensorBasis< d, T > *basis, const index_t pid=-1) | |
Constructs a gsHBox from an element. | |
gsHBox (const gsHBox< d, T > &other) | |
Copy constructor (makes deep copy) | |
gsHBox (const gsHDomainIterator< T, d > *domHIt) | |
Constructs a gsHBox from a domain iterator. | |
gsHBox (const gsHDomainIterator< T, d > *domHIt, const index_t pid) | |
Constructs a gsHBox from a domain iterator. | |
gsHBox (const std::vector< index_t > &indices, const gsHTensorBasis< d, T > *basis, const index_t pid=-1) | |
Constructs a gsHBox from an element. | |
gsHBox (const typename gsHBox< d, T >::point &low, const typename gsHBox< d, T >::point &upp, index_t level, const gsHTensorBasis< d, T > *basis, const index_t pid=-1) | |
Constructs a gsHBox from an element. | |
gsHBox (gsHBox< d, T > &&other) | |
Move constructor. | |
index_t | index () const |
Gets the index stored in the object. | |
bool | isActive () const |
Determines if the box is active on its current level. | |
bool | isActiveOrContained () const |
Determines if active or contained in the active elemebt. In other words; checks if the level of this box is higher or equal to the level of the mesh here. | |
bool | isContained (const gsHBox< d, T > &other) const |
Checks if the other cell is contained in this cell. | |
bool | isSame (const gsHBox< d, T > &other) const |
Determines whether the this box is the same as the other box. | |
index_t | level () const |
Gets the level of the object. | |
index_t | levelInCenter () const |
Gets the level in the center of the object. | |
gsVector< T, d > | lowerCorner () const |
Gets the lower corner of the box. | |
const point & | lowerIndex () const |
Gets the lower index of the box. | |
void | mark () |
Marks this element for refinement. | |
bool | marked () const |
Returns whether the element is marked or not. | |
gsHBox< d, T > & | operator= (const gsHBox< d, T > &other) |
Assignment operator. | |
gsHBox< d, T > & | operator= (gsHBox< d, T > &&other) |
Move assignment operator. | |
index_t | patch () const |
Gets the patch ID of the object. | |
std::ostream & | print (std::ostream &os) const |
Prints the object. | |
T | projectedErrorCrs () const |
The error contribution of *this when it is coarsened. | |
T | projectedErrorRef () const |
The error contribution of *this when it is refined. | |
T | projectedImprovement () const |
Gives the projected improvement that can be expected for this. | |
T | projectedSetBack () const |
Gives the projected set-back that can be expected for this. | |
void | setAndProjectError (T error, index_t alpha=2, index_t beta=0) |
Sets the error of the object and compute the projection of the error on a finer mesh. The projection is performed based on a theoretical rate of convergence of alpha*p+beta. | |
void | setError (T error) |
Sets the error of the object. | |
void | setIndex (index_t index) |
Assigns an index to the object. | |
void | setMark (bool mark) |
Sets the mark. | |
RefBox | toBox () const |
Returns a box representation of the object. | |
Container | toContainer () |
Returns a container representation of the object. | |
RefBox | toCrsBox (index_t targetLevel) const |
Returns a box representation of the object on the higher level (needed for coarsening). | |
HContainer | toHContainer () |
Returns a hierarchical container representation of the object. | |
RefBox | toRefBox (index_t targetLevel) const |
Returns a box representation of the object on the lower level (needed for refinement). | |
Container | toUnitBoxes () const |
Returns unit boxes representation of the object. | |
void | unmark () |
Unmarks this element for refinement. | |
gsVector< T, d > | upperCorner () const |
Gets the upper corner of the box. | |
const point & | upperIndex () const |
Gets the upper index of the box. | |
gsHBox | ( | const gsHDomainIterator< T, d > * | domHIt | ) |
Constructs a gsHBox from a domain iterator.
[in] | domHIt | A hierarchical domain iterator |
gsHBox | ( | const gsHDomainIterator< T, d > * | domHIt, |
const index_t | pid | ||
) |
Constructs a gsHBox from a domain iterator.
[in] | domHIt | A hierarchical domain iterator |
[in] | pid | The patch ID |
gsHBox | ( | const typename gsHBox< d, T >::point & | low, |
const typename gsHBox< d, T >::point & | upp, | ||
index_t | level, | ||
const gsHTensorBasis< d, T > * | basis, | ||
const index_t | pid = -1 |
||
) |
Constructs a gsHBox from an element.
[in] | low | The lower corner of the element, see gsHTensorBasis |
[in] | upp | The upper corner of the element, see gsHTensorBasis |
[in] | level | The level of the element |
[in] | basis | The basis on which the element is defined |
[in] | pid | The patch ID |
gsHBox | ( | const gsAABB< d, index_t > & | box, |
const gsHTensorBasis< d, T > * | basis, | ||
const index_t | pid = -1 |
||
) |
Constructs a gsHBox from an element.
[in] | box | The box as AABB box |
[in] | basis | The basis on which the element is defined |
[in] | pid | The patch ID |
gsHBox | ( | const std::vector< index_t > & | indices, |
const gsHTensorBasis< d, T > * | basis, | ||
const index_t | pid = -1 |
||
) |
Constructs a gsHBox from an element.
[in] | indices | Element definition (+ level) as in gsHTensorBasis. This object is 2*d+1 long |
[in] | basis | The basis on which the element is defined |
[in] | pid | The patch ID |
void clean | ( | Container & | container | ) | const |
Cleans the container from bad elements (see good())
container | The container |
Checks if the other cell is contains in this cell.
other | The other cell |
T error | ( | ) | const |
Gets the error stored in the object.
Gets the ancestor of the object on level k.
[in] | k | The reference level |
Gets the center of the box.
Gets the Coarsening extension, which is the coarsening neighborhood before checking for active elements.
[in] | m | The jump parameter |
Gets the children of the object.
Gets the Coarsening neighborhood.
[in] | m | The jump parameter |
Gets the coordinates of the box (first column lower corner, second column higher corner).
Gets the descendants of the object on level k.
[in] | k | The reference level |
Gets the H-neighborhood.
[in] | m | The jump parameter |
Gets the multi-level support extension.
[in] | k | The reference level |
|
inline |
Gets the neighborhood.
[in] | m | The jump parameter |
_mode | H or T refinement (else not implemented) |
Gets the refinement neighborhood. Returns either the H- or T-neighborhood, depending on the underlying basis.
[in] | m | The jump parameter |
Gets the parent of the object.
Gets the support extension.
Gets the T-neighborhood.
[in] | m | The jump parameter |
bool good | ( | ) | const |
Checks if the box has positive indices.
Gets the index stored in the object.
bool isActive | ( | ) | const |
Determines if the box is active on its current level.
bool isActiveOrContained | ( | ) | const |
Determines if active or contained in the active elemebt. In other words; checks if the level of this box is higher or equal to the level of the mesh here.
Checks if the other cell is contained in this cell.
other | The other cell |
Determines whether the this box is the same as the other box.
[in] | other | The other box |
Gets the level of the object.
Gets the level in the center of the object.
Gets the lower corner of the box.
Gets the lower index of the box.
bool marked | ( | ) | const |
Returns whether the element is marked or not.
Gets the patch ID of the object.
T projectedErrorCrs | ( | ) | const |
The error contribution of *this when it is coarsened.
Note: this means that
T projectedErrorRef | ( | ) | const |
The error contribution of *this when it is refined.
T projectedImprovement | ( | ) | const |
Gives the projected improvement that can be expected for this.
T projectedSetBack | ( | ) | const |
Gives the projected set-back that can be expected for this.
void setMark | ( | bool | mark | ) |
Sets the mark.
[in] | mark | The mark |
Returns a box representation of the object.
Returns a container representation of the object.
Returns a box representation of the object on the higher level (needed for coarsening).
Returns a hierarchical container representation of the object.
Returns a box representation of the object on the lower level (needed for refinement).
Returns unit boxes representation of the object.
Gets the upper corner of the box.