|
preCICE v3.3.0
|
#include <NearestNeighborBaseMapping.hpp>
Public Member Functions | |
| NearestNeighborBaseMapping (Constraint constraint, int dimensions, bool hasGradient, std::string mappingName, std::string mappingNameShort) | |
| Constructor. | |
| void | computeMapping () final override |
| Computes the mapping coefficients from the in- and output mesh. | |
| void | clear () final override |
| Removes a computed mapping. | |
| virtual void | onMappingComputed (mesh::PtrMesh origins, mesh::PtrMesh searchSpace) |
| void | tagMeshFirstRound () final override |
| Method used by partition. Tags vertices that could be owned by this rank. | |
| void | tagMeshSecondRound () final override |
| Method used by partition. Tags vertices that can be filtered out. | |
| Public Member Functions inherited from precice::mapping::Mapping | |
| Mapping (Constraint constraint, int dimensions, bool requiresGradientData, InitialGuessRequirement initialGuessRequirement) | |
| Constructor, takes mapping constraint. | |
| Mapping & | operator= (Mapping &&)=delete |
| virtual | ~Mapping ()=default |
| Destructor, empty. | |
| void | setMeshes (const mesh::PtrMesh &input, const mesh::PtrMesh &output) |
| Sets input and output meshes carrying data to be mapped. | |
| const mesh::PtrMesh & | getInputMesh () const |
| const mesh::PtrMesh & | getOutputMesh () const |
| Constraint | getConstraint () const |
| Returns the constraint (consistent/conservative) of the mapping. | |
| MeshRequirement | getInputRequirement () const |
| Returns the requirement on the input mesh. | |
| MeshRequirement | getOutputRequirement () const |
| Returns the requirement on the output mesh. | |
| bool | hasComputedMapping () const |
| Returns true, if the mapping has been computed. | |
| virtual bool | hasConstraint (const Constraint &constraint) const |
| Checks whether the mapping has the given constraint or not. | |
| bool | isScaledConsistent () const |
| Returns true if mapping is a form of scaled consistent mapping. | |
| bool | requiresInitialGuess () const |
| Return true if the mapping requires an initial guess. | |
| bool | isJustInTimeMapping () const |
| const Eigen::VectorXd & | initialGuess () const |
| Return the provided initial guess of a mapping using an initialGuess. | |
| Eigen::VectorXd & | initialGuess () |
| bool | hasInitialGuess () const |
| True if initialGuess().size() == 0. | |
| void | map (int inputDataID, int outputDataID) |
| void | map (int inputDataID, int outputDataID, Eigen::VectorXd &initialGuess) |
| void | map (const time::Sample &input, Eigen::VectorXd &output) |
| Maps an input Sample to output data from input mesh to output mesh. | |
| void | map (const time::Sample &input, Eigen::VectorXd &output, Eigen::VectorXd &initialGuess) |
| Maps an input Sample to output data from input mesh to output mesh, given an initialGuess. | |
| virtual void | scaleConsistentMapping (const Eigen::VectorXd &input, Eigen::VectorXd &output, Constraint type) const |
| Scales the consistently mapped output data such that the surface integral of the values on input mesh and output mesh are equal. | |
| bool | requiresGradientData () const |
| Returns whether the mapping requires gradient data. | |
| virtual std::string | getName () const =0 |
| Returns the name of the mapping method for logging purpose. | |
| virtual void | mapConservativeAt (const Eigen::Ref< const Eigen::MatrixXd > &coordinates, const Eigen::Ref< const Eigen::MatrixXd > &source, impl::MappingDataCache &cache, Eigen::Ref< Eigen::MatrixXd > target) |
| Just-in-time mapping variant of mapConservative. | |
| virtual void | mapConsistentAt (const Eigen::Ref< const Eigen::MatrixXd > &coordinates, const impl::MappingDataCache &cache, Eigen::Ref< Eigen::MatrixXd > values) |
| Just-in-time mapping variant of mapConsistent. | |
| virtual void | updateMappingDataCache (impl::MappingDataCache &cache, const Eigen::Ref< const Eigen::VectorXd > &in) |
| Allows updating a so-called MappingDataCache for more efficient just-in-time mappings. | |
| virtual void | initializeMappingDataCache (impl::MappingDataCache &cache) |
| Allocates memory and sets up the data structures inside the MappingDataCache. | |
| virtual void | completeJustInTimeMapping (impl::MappingDataCache &cache, Eigen::Ref< Eigen::MatrixXd > result) |
| Completes a just-in-time mapping for conservative constraints. | |
Protected Attributes | |
| std::string | mappingName |
| NearestNeighborMapping or NearestNeighborGradientMapping. | |
| std::string | mappingNameShort |
| nn or nng | |
| logging::Logger | _log {"mapping::" + mappingName} |
| std::vector< Eigen::VectorXd > | _offsetsMatched |
| std::vector< int > | _vertexIndices |
| Computed output vertex indices to map data from input vertices to. | |
| Protected Attributes inherited from precice::mapping::Mapping | |
| bool | _hasComputedMapping = false |
| Flag to indicate whether computeMapping() has been called. | |
| bool | _requiresGradientData |
| Flag if gradient data is required for the mapping. | |
Additional Inherited Members | |
| Public Types inherited from precice::mapping::Mapping | |
| enum | Constraint { CONSISTENT , CONSERVATIVE , SCALED_CONSISTENT_SURFACE , SCALED_CONSISTENT_VOLUME } |
| Specifies additional constraints for a mapping. More... | |
| enum class | MeshRequirement { UNDEFINED = 0 , VERTEX = 1 , FULL = 2 } |
| Specifies requirements for the input and output meshes of a mapping. More... | |
| enum class | InitialGuessRequirement : bool { Required = true , None = false } |
| Specifies whether the mapping requires an initial guess. More... | |
| Protected Member Functions inherited from precice::mapping::Mapping | |
| mesh::PtrMesh | input () const |
| Returns pointer to input mesh. | |
| mesh::PtrMesh | output () const |
| Returns pointer to output mesh. | |
| void | setInputRequirement (MeshRequirement requirement) |
| Sets the mesh requirement for the input mesh. | |
| void | setOutputRequirement (MeshRequirement requirement) |
| Sets the mesh requirement for the output mesh. | |
| int | getDimensions () const |
| virtual void | mapConservative (const time::Sample &input, Eigen::VectorXd &output)=0 |
| Maps data using a conservative constraint. | |
| virtual void | mapConsistent (const time::Sample &input, Eigen::VectorXd &output)=0 |
| Maps data using a consistent constraint. | |
Mapping using nearest neighboring vertices and (eventually) their local gradient values. Base class for Nearest Neighbor Mapping and Nearest Neighbor Gradient
Definition at line 12 of file NearestNeighborBaseMapping.hpp.
| precice::mapping::NearestNeighborBaseMapping::NearestNeighborBaseMapping | ( | Constraint | constraint, |
| int | dimensions, | ||
| bool | hasGradient, | ||
| std::string | mappingName, | ||
| std::string | mappingNameShort ) |
Constructor.
| [in] | constraint | Specifies mapping to be consistent or conservative. |
| [in] | dimensions | Dimensionality of the meshes |
Definition at line 18 of file NearestNeighborBaseMapping.cpp.
|
finaloverridevirtual |
Removes a computed mapping.
Implements precice::mapping::Mapping.
Definition at line 86 of file NearestNeighborBaseMapping.cpp.
|
finaloverridevirtual |
Computes the mapping coefficients from the in- and output mesh.
Implements precice::mapping::Mapping.
Definition at line 30 of file NearestNeighborBaseMapping.cpp.
|
virtual |
Matches the offsets needed for the gradient mapping Does nothing by default
Reimplemented in precice::mapping::NearestNeighborGradientMapping.
Definition at line 102 of file NearestNeighborBaseMapping.cpp.
|
finaloverridevirtual |
Method used by partition. Tags vertices that could be owned by this rank.
Implements precice::mapping::Mapping.
Definition at line 107 of file NearestNeighborBaseMapping.cpp.
|
finaloverridevirtual |
Method used by partition. Tags vertices that can be filtered out.
Implements precice::mapping::Mapping.
Definition at line 149 of file NearestNeighborBaseMapping.cpp.
|
mutableprotected |
Definition at line 45 of file NearestNeighborBaseMapping.hpp.
|
protected |
Compute the vector offset between the matched vector and the source vector (needed for gradient mapping) Optimization: save this as an std::vector<double> and use an Eigen::Map to create an interface that uses the correct dimensions.
Definition at line 49 of file NearestNeighborBaseMapping.hpp.
|
protected |
Computed output vertex indices to map data from input vertices to.
Definition at line 52 of file NearestNeighborBaseMapping.hpp.
|
protected |
NearestNeighborMapping or NearestNeighborGradientMapping.
Definition at line 40 of file NearestNeighborBaseMapping.hpp.
|
protected |
nn or nng
Definition at line 43 of file NearestNeighborBaseMapping.hpp.