|
OPALX (Object Oriented Parallel Accelerator Library for Exascal) MINIorX
OPALX
|
#include <TriLinearInterpolator.h>
Public Member Functions | |
| TriLinearInterpolator (ThreeDGrid *grid, double ***F) | |
| TriLinearInterpolator (const TriLinearInterpolator &tli) | |
| ~TriLinearInterpolator () | |
| void | function (const double Point[3], double Value[1]) const |
| virtual void | function (const Mesh::Iterator &point, double *value) const |
| TriLinearInterpolator * | clone () const |
| double *** | function () const |
| virtual void | function (const double *point, double *value) const =0 |
| int | getNumberOfXCoords () const |
| int | getNumberOfYCoords () const |
| int | getNumberOfZCoords () const |
| unsigned int | getPointDimension () const |
| unsigned int | getValueDimension () const |
| ThreeDGrid * | getMesh () const |
| void | setGrid (ThreeDGrid *grid) |
| void | setX (int nCoords, double *x) |
| void | setY (int nCoords, double *y) |
| void | setZ (int nCoords, double *z) |
| void | setF (double ***inF) |
| void | deleteFunc (double ***func) |
| void | setAll (ThreeDGrid *grid, double ***F) |
| void | clear () |
| virtual void | functionAppend (const std::vector< std::vector< double > > &point_vec, std::vector< std::vector< double > > &value_vec) const |
| virtual bool | checkPoint (const std::vector< double > &point) const |
| virtual bool | checkValue (const std::vector< double > &value) const |
Protected Attributes | |
| ThreeDGrid * | coordinates_m |
| double *** | f_m |
TriLinearInterpolator performs a linear interpolation in x then y then z
Performs a linear interpolation in x then y then z returning a 1D value.
Definition at line 38 of file TriLinearInterpolator.h.
|
inline |
Constructor for grids with constant spacing
| grid | 3d mesh on which data is stored - adds a reference to *this into the mesh smart pointer thing. |
| F | function data with points on each element of the grid. Indexing goes like [index_x][index_y][index_z]. Interpolator3dGridTo1d now owns this memory All the data handling is done at Interpolator3dGridTo1d |
Definition at line 83 of file TriLinearInterpolator.h.
References interpolation::Interpolator3dGridTo1d::Interpolator3dGridTo1d().
Referenced by clone(), and TriLinearInterpolator().
| interpolation::TriLinearInterpolator::TriLinearInterpolator | ( | const TriLinearInterpolator & | tli | ) |
Copy constructor
Deep copies the mesh and the function data
Definition at line 32 of file TriLinearInterpolator.cpp.
References interpolation::Interpolator3dGridTo1d::coordinates_m, interpolation::Interpolator3dGridTo1d::f_m, interpolation::Interpolator3dGridTo1d::Interpolator3dGridTo1d(), and TriLinearInterpolator().
|
inline |
Destructor - removes reference from the mesh and from the function data
Definition at line 87 of file TriLinearInterpolator.h.
|
inlinevirtualinherited |
Return true if point.size() is the same as this->PointDimension()
Definition at line 95 of file VectorMap.h.
|
inlinevirtualinherited |
Return true if value.size() is the same as this->ValueDimension()
Definition at line 99 of file VectorMap.h.
|
inlineinherited |
Clear all private data
Definition at line 216 of file Interpolator3dGridTo1d.h.
References coordinates_m, deleteFunc(), and f_m.
Referenced by ~Interpolator3dGridTo1d().
|
inlinevirtual |
Copy function (can be called on parent class)
Implements interpolation::Interpolator3dGridTo1d.
Definition at line 90 of file TriLinearInterpolator.h.
References TriLinearInterpolator().
|
inherited |
Delete any existing function data
Definition at line 31 of file Interpolator3dGridTo1d.cpp.
References getNumberOfXCoords(), and getNumberOfYCoords().
Referenced by clear(), and setF().
|
inlineinherited |
Return a pointer to the function data
Definition at line 207 of file Interpolator3dGridTo1d.h.
References f_m.
|
virtual |
Get the interpolated value of the function at some point
First does bound checking, then makes linear interpolations using the standard 1d interpolation formula
\(y(x) \approx \frac{\Delta y}{\Delta x} dx + y_0\)
\(y(x) \approx \frac{y_1(x_1)-y_0(x_0)}{dx}(x-x_0) + y_0\)
Interpolate along 4 x grid lines to make a 2D problem, then interpolate along 2 y grid lines to make a 1D problem, then finally interpolate in z to get the value.
Implements interpolation::Interpolator3dGridTo1d.
Definition at line 48 of file TriLinearInterpolator.cpp.
References interpolation::Interpolator3dGridTo1d::coordinates_m, interpolation::Interpolator3dGridTo1d::f_m, and Point.
|
inlinevirtual |
Call function at a particular point in the mesh
Reimplemented from interpolation::Interpolator3dGridTo1d.
Definition at line 74 of file TriLinearInterpolator.h.
References interpolation::VectorMap::function().
|
pure virtualinherited |
Pure virtual function to fill the array value with data evaluated at point.
Implemented in interpolation::PolynomialPatch.
Referenced by interpolation::Interpolator3dGridTo1d::function(), interpolation::Interpolator3dGridTo3d::function(), interpolation::TriLinearInterpolator::function(), function(), and functionAppend().
|
inlinevirtualinherited |
Calculate F, appending output values to value_vec.
For each item in point_vec not in value_vec, calculate value_vec (urgh)
Definition at line 109 of file VectorMap.h.
References function(), and getValueDimension().
|
inlinevirtualinherited |
Return a pointer to the mesh
Reimplemented from interpolation::VectorMap.
Definition at line 176 of file Interpolator3dGridTo1d.h.
References coordinates_m.
|
inlineinherited |
Number of x coordinates in the grid
Definition at line 156 of file Interpolator3dGridTo1d.h.
References coordinates_m.
Referenced by deleteFunc().
|
inlineinherited |
Number of y coordinates in the grid
Definition at line 160 of file Interpolator3dGridTo1d.h.
References coordinates_m.
Referenced by deleteFunc().
|
inlineinherited |
Number of z coordinates in the grid
Definition at line 164 of file Interpolator3dGridTo1d.h.
References coordinates_m.
|
inlinevirtualinherited |
Dimension of input points
Implements interpolation::VectorMap.
Definition at line 168 of file Interpolator3dGridTo1d.h.
|
inlinevirtualinherited |
Dimension of output values
Implements interpolation::VectorMap.
Definition at line 172 of file Interpolator3dGridTo1d.h.
|
inlineinherited |
Set function and mesh data
Definition at line 211 of file Interpolator3dGridTo1d.h.
References setF(), and setGrid().
Referenced by Interpolator3dGridTo1d().
|
inlineinherited |
Set function data, deleting any existing function data
Definition at line 180 of file Interpolator3dGridTo1d.h.
References deleteFunc(), and f_m.
Referenced by setAll().
|
inlineinherited |
Reset the mesh
Removes reference to this from mesh smart pointer if appropriate
Definition at line 185 of file Interpolator3dGridTo1d.h.
References interpolation::ThreeDGrid::add(), and coordinates_m.
Referenced by setAll().
|
inlineinherited |
Set x coordinates in the mesh to an arbitrary set of points
If mesh is nullptr, does nothing
Definition at line 192 of file Interpolator3dGridTo1d.h.
References coordinates_m.
|
inlineinherited |
Set y coordinates in the mesh to an arbitrary set of points
If mesh is nullptr, does nothing
Definition at line 197 of file Interpolator3dGridTo1d.h.
References coordinates_m.
|
inlineinherited |
Set z coordinates in the mesh to an arbitrary set of points
If mesh is nullptr, does nothing
Definition at line 202 of file Interpolator3dGridTo1d.h.
References coordinates_m.
|
protectedinherited |
Definition at line 139 of file Interpolator3dGridTo1d.h.
Referenced by clear(), interpolation::TriLinearInterpolator::function(), getMesh(), getNumberOfXCoords(), getNumberOfYCoords(), getNumberOfZCoords(), Interpolator3dGridTo1d(), Interpolator3dGridTo1d(), setGrid(), setX(), setY(), setZ(), and interpolation::TriLinearInterpolator::TriLinearInterpolator().
|
protectedinherited |
Definition at line 140 of file Interpolator3dGridTo1d.h.
Referenced by clear(), function(), interpolation::TriLinearInterpolator::function(), Interpolator3dGridTo1d(), Interpolator3dGridTo1d(), setF(), and interpolation::TriLinearInterpolator::TriLinearInterpolator().