G+Smo  25.01.0
Geometry + Simulation Modules
 
Loading...
Searching...
No Matches
gsHBox< d, T > Class Template Reference

Detailed Description

template<int d, class T>
class gismo::gsHBox< d, T >

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.

Template Parameters
dDomain dimension
TReal type
+ Collaboration diagram for gsHBox< d, T >:

Public Types

typedef memory::shared_ptr< gsHBoxPtr
 Shared pointer for gsHTensorBasis.
 
typedef memory::unique_ptr< gsHBoxuPtr
 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.
 
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.
 
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.
 
getMaxCellLength () const
 Return the length of the largest edge of the element.
 
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 pointlowerIndex () 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.
 
projectedErrorCrs () const
 The error contribution of *this when it is coarsened.
 
projectedErrorRef () const
 The error contribution of *this when it is refined.
 
projectedImprovement () const
 Gives the projected improvement that can be expected for this.
 
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 pointupperIndex () const
 Gets the upper index of the box.
 

Constructor & Destructor Documentation

◆ gsHBox() [1/5]

template<short_t d, class T >
gsHBox ( const gsHDomainIterator< T, d > *  domHIt)

Constructs a gsHBox from a domain iterator.

Parameters
[in]domHItA hierarchical domain iterator

◆ gsHBox() [2/5]

template<short_t d, class T >
gsHBox ( const gsHDomainIterator< T, d > *  domHIt,
const index_t  pid 
)

Constructs a gsHBox from a domain iterator.

Parameters
[in]domHItA hierarchical domain iterator
[in]pidThe patch ID

◆ gsHBox() [3/5]

template<short_t d, class T >
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.

Parameters
[in]lowThe lower corner of the element, see gsHTensorBasis
[in]uppThe upper corner of the element, see gsHTensorBasis
[in]levelThe level of the element
[in]basisThe basis on which the element is defined
[in]pidThe patch ID

◆ gsHBox() [4/5]

template<short_t d, class T >
gsHBox ( const gsAABB< d, index_t > &  box,
const gsHTensorBasis< d, T > *  basis,
const index_t  pid = -1 
)

Constructs a gsHBox from an element.

Parameters
[in]boxThe box as AABB box
[in]basisThe basis on which the element is defined
[in]pidThe patch ID

◆ gsHBox() [5/5]

template<short_t d, class T >
gsHBox ( const std::vector< index_t > &  indices,
const gsHTensorBasis< d, T > *  basis,
const index_t  pid = -1 
)

Constructs a gsHBox from an element.

Parameters
[in]indicesElement definition (+ level) as in gsHTensorBasis. This object is 2*d+1 long
[in]basisThe basis on which the element is defined
[in]pidThe patch ID

Member Function Documentation

◆ clean()

template<short_t d, class T >
void clean ( Container &  container) const

Cleans the container from bad elements (see good())

Parameters
containerThe container

◆ contains()

template<short_t d, class T >
bool contains ( const gsHBox< d, T > &  other) const

Checks if the other cell is contains in this cell.

Parameters
otherThe other cell
Returns
True if the specified other is contains in the cell, False otherwise.

◆ error()

template<short_t d, class T >
T error ( ) const

Gets the error stored in the object.

Returns
The error of the object

◆ getAncestor()

template<short_t d, class T >
gsHBox< d, T > getAncestor ( index_t  k) const

Gets the ancestor of the object on level k.

Parameters
[in]kThe reference level
Returns
The ancestor.

◆ getCenter()

template<short_t d, class T >
const gsMatrix< T > & getCenter ( ) const

Gets the center of the box.

Returns
The center of the box.

◆ getCextension()

template<short_t d, class T >
gsHBox< d, T >::Container getCextension ( index_t  m)

Gets the Coarsening extension, which is the coarsening neighborhood before checking for active elements.

Parameters
[in]mThe jump parameter
Returns
The coarsening extension.

◆ getChildren()

template<short_t d, class T >
gsHBox< d, T >::Container getChildren ( ) const

Gets the children of the object.

Returns
The children of the object.

◆ getCneighborhood()

template<short_t d, class T >
gsHBox< d, T >::Container getCneighborhood ( index_t  m)

Gets the Coarsening neighborhood.

Parameters
[in]mThe jump parameter
Returns
The coarsening neighborhood.

◆ getCoordinates()

template<short_t d, class T >
const gsMatrix< T > & getCoordinates ( ) const

Gets the coordinates of the box (first column lower corner, second column higher corner).

Returns
The coordinates of the box.

◆ getDescendants()

template<short_t d, class T >
gsHBox< d, T >::Container getDescendants ( index_t  k) const

Gets the descendants of the object on level k.

Parameters
[in]kThe reference level
Returns
The children of the object.

◆ getHneighborhood()

template<short_t d, class T >
gsHBox< d, T >::Container getHneighborhood ( index_t  m)

Gets the H-neighborhood.

Parameters
[in]mThe jump parameter
Returns
The H-neighborhood.

◆ getMultiLevelSupportExtension()

template<short_t d, class T >
gsHBox< d, T >::Container getMultiLevelSupportExtension ( index_t  k)

Gets the multi-level support extension.

Parameters
[in]kThe reference level
Returns
The multi-level support extension.

◆ getNeighborhood() [1/2]

template<int d, class T >
template<gsHNeighborhood _mode>
gsHBox< d, T >::Container getNeighborhood ( index_t  m)
inline

Gets the neighborhood.

Parameters
[in]mThe jump parameter
Template Parameters
_modeH or T refinement (else not implemented)
Returns
The neighborhood.

◆ getNeighborhood() [2/2]

template<short_t d, class T >
gsHBox< d, T >::Container getNeighborhood ( index_t  m)

Gets the refinement neighborhood. Returns either the H- or T-neighborhood, depending on the underlying basis.

Parameters
[in]mThe jump parameter
Returns
The T-neighborhood.

◆ getParent()

template<short_t d, class T >
gsHBox< d, T > getParent ( ) const

Gets the parent of the object.

Returns
The parent of the object.

◆ getSupportExtension()

template<short_t d, class T >
gsHBox< d, T >::Container getSupportExtension ( )

Gets the support extension.

Returns
The support extension.

◆ getTneighborhood()

template<short_t d, class T >
gsHBox< d, T >::Container getTneighborhood ( index_t  m)

Gets the T-neighborhood.

Parameters
[in]mThe jump parameter
Returns
The T-neighborhood.

◆ good()

template<short_t d, class T >
bool good ( ) const

Checks if the box has positive indices.

Returns
True if the box has positive indices, false otherwise

◆ index()

template<short_t d, class T >
index_t index ( ) const

Gets the index stored in the object.

Returns
The index of the object

◆ isActive()

template<short_t d, class T >
bool isActive ( ) const

Determines if the box is active on its current level.

Returns
True if active, False otherwise.

◆ isActiveOrContained()

template<short_t d, class T >
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.

Returns
True if active or contained, False otherwise.

◆ isContained()

template<short_t d, class T >
bool isContained ( const gsHBox< d, T > &  other) const

Checks if the other cell is contained in this cell.

Parameters
otherThe other cell
Returns
True if the specified other is contained in the cell, False otherwise.

◆ isSame()

template<short_t d, class T >
bool isSame ( const gsHBox< d, T > &  other) const

Determines whether the this box is the same as the other box.

Parameters
[in]otherThe other box
Returns
True if the boxes are the same, False otherwise.

◆ level()

template<short_t d, class T >
index_t level ( ) const

Gets the level of the object.

Returns
The level of the object

◆ levelInCenter()

template<short_t d, class T >
index_t levelInCenter ( ) const

Gets the level in the center of the object.

Returns
The level in the center of the object

◆ lowerCorner()

template<short_t d, class T >
gsVector< T, d > lowerCorner ( ) const

Gets the lower corner of the box.

Returns
The lower corner

◆ lowerIndex()

template<short_t d, class T >
const gsHBox< d, T >::point & lowerIndex ( ) const

Gets the lower index of the box.

Returns
The lower index

◆ marked()

template<short_t d, class T >
bool marked ( ) const

Returns whether the element is marked or not.

Returns
this is marked

◆ patch()

template<short_t d, class T >
index_t patch ( ) const

Gets the patch ID of the object.

Returns
The patch ID of the object

◆ projectedErrorCrs()

template<short_t d, class T >
T projectedErrorCrs ( ) const

The error contribution of *this when it is coarsened.

        Note: this means that
Returns
The error of the object

◆ projectedErrorRef()

template<short_t d, class T >
T projectedErrorRef ( ) const

The error contribution of *this when it is refined.

Returns
The error of the object

◆ projectedImprovement()

template<short_t d, class T >
T projectedImprovement ( ) const

Gives the projected improvement that can be expected for this.

Returns
The projected improvement

◆ projectedSetBack()

template<short_t d, class T >
T projectedSetBack ( ) const

Gives the projected set-back that can be expected for this.

Returns
The projected improvement

◆ setMark()

template<short_t d, class T >
void setMark ( bool  mark)

Sets the mark.

Parameters
[in]markThe mark

◆ toBox()

template<short_t d, class T >
gsHBox< d, T >::RefBox toBox ( ) const

Returns a box representation of the object.

Returns
Box representation of the object.

◆ toContainer()

template<short_t d, class T >
gsHBox< d, T >::Container toContainer ( )

Returns a container representation of the object.

Returns
Container representation of the object.

◆ toCrsBox()

template<short_t d, class T >
gsHBox< d, T >::RefBox toCrsBox ( index_t  targetLevel) const

Returns a box representation of the object on the higher level (needed for coarsening).

Returns
Coarsening box representation of the object.

◆ toHContainer()

template<short_t d, class T >
gsHBox< d, T >::HContainer toHContainer ( )

Returns a hierarchical container representation of the object.

Returns
Hierarchical container representation of the object.

◆ toRefBox()

template<short_t d, class T >
gsHBox< d, T >::RefBox toRefBox ( index_t  targetLevel) const

Returns a box representation of the object on the lower level (needed for refinement).

Returns
Refinement box representation of the object.

◆ toUnitBoxes()

template<short_t d, class T >
gsHBox< d, T >::Container toUnitBoxes ( ) const

Returns unit boxes representation of the object.

Returns
Unit boxes representation of the object.

◆ upperCorner()

template<short_t d, class T >
gsVector< T, d > upperCorner ( ) const

Gets the upper corner of the box.

Returns
The upper corner

◆ upperIndex()

template<short_t d, class T >
const gsHBox< d, T >::point & upperIndex ( ) const

Gets the upper index of the box.

Returns
The upper index