#include <PUApproximant_fwd.hpp>
An efficient partition-of-unity based approximation method for gluing the local approximations together into a smooth field.
To join the many different local approximations together, a weighted average of the relevant solutions at each point is computed. This can be done continuously and efficiently using a compactly supported partition of unity.
There are more reasonable choices for \( r \), such as the distance to the closest computation node, not included in the neighborhood. The larger the radii \( r \) the more prominent the averaging effect will be.
To evaluate approximant at \( N_q \) points, we can construct a spatial search structure that supports radius based nearest-neighbor queries (such as a \( k \)-d tree).
For more details see this paper.
Definition at line 40 of file PUApproximant_fwd.hpp.
| Static Public Member Functions | |
| static vec_t::scalar_t | weight (typename vec_t::scalar_t r) | 
| Computes \( C^2 \) smooth weights \( w \in \left [ 0, 1 \right ] \).  More... | |
| template<typename scalar_t , typename engine_t > | |
| static eigen_vt< scalar_t > | evaluate (const DomainDiscretization< vec_t > &domain, const eigen_vt< scalar_t > &values, const Range< vec_t > &query_points, d_scalar_t radius_factor, const engine_t &engine) | 
| Evaluates the Partion-of-unity approximant at points 'query_points' constructed on given \( (domain, values) \) pairs.  More... | |
| template<typename scalar_t , typename engine_t > | |
| static eigen_vt< scalar_t > | evaluate (const DomainDiscretization< vec_t > &domain, const eigen_vt< scalar_t > &values, const KDTree< vec_t > &query_points_tree, d_scalar_t radius_factor, const engine_t &engine) | 
| Overload of evaluate using a precomputed \( k \)-d tree.  More... | |
| Private Types | |
| template<typename scalar_t > | |
| using | eigen_vt = Eigen::Matrix< scalar_t, Eigen::Dynamic, 1 > | 
| Vector type.  More... | |
| using | d_scalar_t = typename vec_t::scalar_t | 
| Scalar type.  More... | |
| 
 | static | 
Overload of evaluate using a precomputed \( k \)-d tree.
| 
 | static | 
Evaluates the Partion-of-unity approximant at points 'query_points' constructed on given \( (domain, values) \) pairs.
The order of the approximation is equal to the order of local approximations of \( engine \).
Computational complexity is \( O((N + N_q) \log N_q) \), where \( N \) is the number of points in the domain and \( N_q \) is the number of query points.
Usage example:
| domain | Domain with nodes and stencils. | 
| values | Function values in each domain node. | 
| query_points | Evaluation points where the approximated function should be evaluated. | 
| radius_factor | Local subdomains have radius radius_factor*h, wherehis the distance to the farthest support node. Radius factor must be large enough that local subdomains cover all query points. | 
| engine | Local approximation engine. If the engine is interpolatory, so is the PU approximant. | 
| 
 | inlinestatic | 
Computes \( C^2 \) smooth weights \( w \in \left [ 0, 1 \right ] \).
There are more reasonable choices for \( r \), such as the distance to the closest computation node, not included in the neighborhood. The larger the radii \( r \) the more prominent the averaging effect will be.
| r | Effective radius. | 
Definition at line 56 of file PUApproximant_fwd.hpp.