G+Smo
25.01.0
Geometry + Simulation Modules
|
Class that represents the (tensor) patch quadrature rule.
The class uses the basis to construct the quadrature. The rule uses (and distributes) quadrature points according to a Newton scheme and the number of points and weights is based on the number of points and weights in a target space with a specific order and regularity.
Optionally, one can over-integrate the quadrature rule, meaning that extra quadrature points are added on the boundary elements. The number of points for over integration is equal to the degree of the knot vector of the basis.
The method works as follows(see Johannessen 2017 for more information): Given a vector of quadrature points \(\mathbf{\xi}=[ \xi_1, \xi_2,...\xi_n ]\) (where \(n\) depends on the order and regularity of the target space, the fact that this space provides an even/odd number of points and on over-integration or not) with corresponding weights \(\mathbf{w}=[ w_1, w_2,...w_n ]\). Initially, we know the integrals of our basis functions \( \int_\mathbb{R} N_{j,p}(\xi)\:\text{d}\xi\), \(j=\{1,2,...,m\}\), where \(m\) is the number of basis functions in our space. Then, we want to minimize the residual
\begin{eqnarray*} \mathbf{F} \left( \begin{bmatrix} \mathbf{w} \\ \mathbf{\xi} \end{bmatrix} \right) = \begin{bmatrix} N_{1,p}(\xi_1) & N_{1,p}(\xi_2) & \dots & N_{1,p}(\xi_n)\\ N_{2,p}(\xi_1) & N_{2,p}(\xi_2) & \dots & N_{2,p}(\xi_n)\\ \vdots & & \ddots & \vdots \\ N_{m,p}(\xi_1) & N_{m,p}(\xi_2) & \dots & N_{m,p}(\xi_n) \end{bmatrix} \begin{bmatrix} w_1 \\ w_2 \\ \vdots \\ w_n \end{bmatrix} - \begin{bmatrix} \int N_{1,p}(\xi)\:\text{d}\xi\\ \int N_{2,p}(\xi)\:\text{d}\xi\\ \vdots \\ \int N_{m,p}(\xi)\:\text{d}\xi \end{bmatrix} \end{eqnarray*}
For the Newton iterations, we compute the Jacobian according to \(\mathbf{F}\):
\begin{eqnarray*} \frac{\partial\mathbf{F}}{\partial \mathbf{w}} = \begin{bmatrix} N_{1,p}(\xi_1) & N_{1,p}(\xi_2) & \dots & N_{1,p}(\xi_n)\\ N_{2,p}(\xi_1) & N_{2,p}(\xi_2) & \dots & N_{2,p}(\xi_n)\\ \vdots & & \ddots & \vdots \\ N_{m,p}(\xi_1) & N_{m,p}(\xi_2) & \dots & N_{m,p}(\xi_n) \end{bmatrix} \end{eqnarray*}
\begin{eqnarray*} \frac{\partial\mathbf{F}}{\partial \mathbf{\xi}} = \begin{bmatrix} w_1 N'_{1,p}(\xi_1) & w_1 N'_{1,p}(\xi_2) & \dots & w_1 N'_{1,p}(\xi_n)\\ w_2 N'_{2,p}(\xi_1) & w_2 N'_{2,p}(\xi_2) & \dots & w_2 N'_{2,p}(\xi_n)\\ \vdots & & \ddots & \vdots \\ w_m N'_{m,p}(\xi_1) & w_m N'_{m,p}(\xi_2) & \dots & w_m N'_{m,p}(\xi_n) \end{bmatrix} \end{eqnarray*}
Such that \( \partial \mathbf{F} = \left[ \frac{\partial\mathbf{F}}{\partial \mathbf{w}} , \frac{\partial\mathbf{F}}{\partial \mathbf{\xi}} \right] \in \mathbb{R}^{m\times m}\).
The weights and quadrature points are updated using the Newton update. As an initial guess, we use \( w_i = \int N_{2i,p}(\xi) + N_{2i+1,p}(\xi) \: \text{d}\xi\) and \( \xi_i=\frac{\tau_{2i}+\tau_{2i+1}}{2}\) with \(\tau_i\) the Greville abcissa of basis function \(i\)
Reference: Johannessen, K. A. (2017). Optimal quadrature for univariate and tensor product splines. Computer Methods in Applied Mechanics and Engineering, 316, 84–99. https://doi.org/10.1016/j.cma.2016.04.030
Public Member Functions | |
gsPatchRule () | |
Default empty constructor. | |
gsPatchRule (const gsBasis< T > &basis, const index_t degree, const index_t regularity, const bool overintegrate, const short_t fixDir=-1) | |
Initialize a (tensor-product) patch-rule with based on the basis. | |
void | mapTo (const gsVector< T > &lower, const gsVector< T > &upper, gsMatrix< T > &nodes, gsVector< T > &weights) const |
Maps the points in the d-dimensional cube with points lower and upper. | |
void | mapTo (T startVal, T endVal, gsMatrix< T > &nodes, gsVector< T > &weights) const |
See gsQuadRule for documentation. | |
void | mapToAll (const std::vector< T > &, gsMatrix< T > &, gsVector< T > &) const |
Not implemented! See gsQuadRule for documentation. | |
index_t | numNodes () const |
Number of nodes in the currently kept rule. | |
const gsMatrix< T > & | referenceNodes () const |
Returns reference nodes for the currently kept rule. | |
const gsVector< T > & | referenceWeights () const |
Returns reference weights for the currently kept rule. | |
virtual void | setNodes (gsVector< index_t > const &, unsigned=0) |
Initialize quadrature rule with numNodes number of quadrature points per integration variable. | |
void | setNodes (index_t numNodes, unsigned digits=0) |
Initialize a univariate quadrature rule with numNodes quadrature points. | |
~gsPatchRule () | |
Destructor. | |
Static Public Member Functions | |
static uPtr | make (const gsBasis< T > &basis, const index_t degree, const index_t regularity, const bool overintegrate, const short_t fixDir=-1) |
Make function returning a smart pointer. | |
Protected Member Functions | |
std::pair< gsVector< T >, gsVector< T > > | _compute (const gsKnotVector< T > &knots, const gsMatrix< T > &greville, const gsVector< T > &integrals, const T tol=1e-10) const |
Computes the points and weights for the patch rule using Newton iterations. | |
gsKnotVector< T > | _init (const gsBSplineBasis< T > *Bbasis) const |
Initializes the knot vector for the patch-rule implementation. | |
std::pair< gsMatrix< T >, gsVector< T > > | _integrate (const gsKnotVector< T > &knots) const |
Integrates all basis functions from a knot vector (numerically with Gauss) | |
bool | _isSymmetric (const gsKnotVector< T > knots) const |
Determines whether the specified knot vector is symmetric. | |
index_t | _numQuads (const gsKnotVector< T > knots) const |
Computes the number of quadrature points to exactly integrate the space. | |
void | computeTensorProductRule (const std::vector< gsVector< T > > &nodes, const std::vector< gsVector< T > > &weights) |
Computes the tensor product rule from coordinate-wise 1D nodes and weights. | |
gsPatchRule | ( | const gsBasis< T > & | basis, |
const index_t | degree, | ||
const index_t | regularity, | ||
const bool | overintegrate, | ||
const short_t | fixDir = -1 |
||
) |
Initialize a (tensor-product) patch-rule with based on the basis.
[in] | basis | The basis |
[in] | degree | The degree of the target space |
[in] | regularity | The regularity of the target space |
[in] | overintegrate | Over-integrate (i.e. add p points in boundary elements) when true |
|
protected |
Computes the points and weights for the patch rule using Newton iterations.
knots | The knots of the basis | |
greville | The greville point | |
integrals | The exact integrals | |
[in] | tol | The tolerance |
|
protected |
Initializes the knot vector for the patch-rule implementation.
The knot vector for the basis in a specific direction is modified: 1) the number of knots is made even. If this is not the case, an extra knot is added in the middle 2) over-integration is applied. In this case, p knots are added to the boundary elements
[in] | Bbasis | a gsBSplineBasis |
|
protected |
Integrates all basis functions from a knot vector (numerically with Gauss)
This computes the integrals of the basis function for the newton integration.
knots | The knots |
|
inlineprotected |
Determines whether the specified knot vector is symmetric.
[in] | knots | knot vector |
|
inlineprotected |
Computes the number of quadrature points to exactly integrate the space.
[in] | knots | knot vector |
|
inlinestatic |
Make function returning a smart pointer.
Construct a smart-pointer to the quadrature rule
[in] | basis | The basis |
[in] | degree | The degree of the target space |
[in] | regularity | The regularity of the target space |
[in] | overintegrate | Over-integrate (i.e. add p points in boundary elements) when true |
|
virtual |
Maps the points in the d-dimensional cube with points lower and upper.
See gsQuadRule for documentation
[in] | lower | The lower corner |
[in] | upper | The upper corner |
nodes | Quadrature points | |
weights | Quadrature weights |
Reimplemented from gsQuadRule< T >.
|
inlineinherited |
Returns reference nodes for the currently kept rule.
|
inlineinherited |
Returns reference weights for the currently kept rule.
|
inlinevirtualinherited |
Initialize quadrature rule with numNodes number of quadrature points per integration variable.
The call of this function initializes the quadrature rule for further use, i.e., the quadrature points and weights on the reference cube are set up and stored. The dimension d of the reference cube is specified by the length of the vector numNodes.
Example: numNodes = [2,5] corresponds to quadrature in 2D where two quadrature points are used for the first coordinate and five quadrature points for the second coordinate. In this case, 2*5 = 10 quadrature nodes and weights are set up.
Parameters
numNodes vector of length digits containing numbers of nodes to be used (per integration variable).
digits accuracy of nodes and weights. If 0, the quadrature rule will use precomputed tables if possible. If greater then 0, it will force to compute it everytime.
Reimplemented in gsGaussRule< T >, gsLobattoRule< T >, and gsNewtonCotesRule< T >.
|
inlineinherited |
Initialize a univariate quadrature rule with numNodes quadrature points.
numNodes | quadrature point |
digits | accuracy of nodes and weights. If 0, the quadrature rule will use precomputed tables if possible. If greater then 0, it will force to compute it everytime. |