OPALX (Object Oriented Parallel Accelerator Library for Exascal) MINIorX
OPALX
interpolation::TriLinearInterpolator Class Referenceabstract

#include <TriLinearInterpolator.h>

Inheritance diagram for interpolation::TriLinearInterpolator:
Collaboration diagram for interpolation::TriLinearInterpolator:

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
TriLinearInterpolatorclone () 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
ThreeDGridgetMesh () 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

ThreeDGridcoordinates_m
double *** f_m

Detailed Description

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.

Constructor & Destructor Documentation

◆ TriLinearInterpolator() [1/2]

interpolation::TriLinearInterpolator::TriLinearInterpolator ( ThreeDGrid * grid,
double *** F )
inline

Constructor for grids with constant spacing

Parameters
grid3d mesh on which data is stored - adds a reference to *this into the mesh smart pointer thing.
Ffunction 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().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ TriLinearInterpolator() [2/2]

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().

Here is the call graph for this function:

◆ ~TriLinearInterpolator()

interpolation::TriLinearInterpolator::~TriLinearInterpolator ( )
inline

Destructor - removes reference from the mesh and from the function data

Definition at line 87 of file TriLinearInterpolator.h.

Member Function Documentation

◆ checkPoint()

bool interpolation::VectorMap::checkPoint ( const std::vector< double > & point) const
inlinevirtualinherited

Return true if point.size() is the same as this->PointDimension()

Definition at line 95 of file VectorMap.h.

◆ checkValue()

bool interpolation::VectorMap::checkValue ( const std::vector< double > & value) const
inlinevirtualinherited

Return true if value.size() is the same as this->ValueDimension()

Definition at line 99 of file VectorMap.h.

◆ clear()

void interpolation::Interpolator3dGridTo1d::clear ( )
inlineinherited

Clear all private data

Definition at line 216 of file Interpolator3dGridTo1d.h.

References coordinates_m, deleteFunc(), and f_m.

Referenced by ~Interpolator3dGridTo1d().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ clone()

TriLinearInterpolator * interpolation::TriLinearInterpolator::clone ( ) const
inlinevirtual

Copy function (can be called on parent class)

Implements interpolation::Interpolator3dGridTo1d.

Definition at line 90 of file TriLinearInterpolator.h.

References TriLinearInterpolator().

Here is the call graph for this function:

◆ deleteFunc()

void interpolation::Interpolator3dGridTo1d::deleteFunc ( double *** func)
inherited

Delete any existing function data

Definition at line 31 of file Interpolator3dGridTo1d.cpp.

References getNumberOfXCoords(), and getNumberOfYCoords().

Referenced by clear(), and setF().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ function() [1/4]

double *** interpolation::Interpolator3dGridTo1d::function ( ) const
inlineinherited

Return a pointer to the function data

Definition at line 207 of file Interpolator3dGridTo1d.h.

References f_m.

◆ function() [2/4]

void interpolation::TriLinearInterpolator::function ( const double Point[3],
double Value[1] ) const
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.

◆ function() [3/4]

virtual void interpolation::TriLinearInterpolator::function ( const Mesh::Iterator & point,
double * value ) const
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().

Here is the call graph for this function:

◆ function() [4/4]

virtual void interpolation::VectorMap::function ( const double * point,
double * value ) const
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().

Here is the caller graph for this function:

◆ functionAppend()

void interpolation::VectorMap::functionAppend ( const std::vector< std::vector< double > > & point_vec,
std::vector< std::vector< double > > & value_vec ) const
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().

Here is the call graph for this function:

◆ getMesh()

ThreeDGrid * interpolation::Interpolator3dGridTo1d::getMesh ( ) const
inlinevirtualinherited

Return a pointer to the mesh

Reimplemented from interpolation::VectorMap.

Definition at line 176 of file Interpolator3dGridTo1d.h.

References coordinates_m.

◆ getNumberOfXCoords()

int interpolation::Interpolator3dGridTo1d::getNumberOfXCoords ( ) const
inlineinherited

Number of x coordinates in the grid

Definition at line 156 of file Interpolator3dGridTo1d.h.

References coordinates_m.

Referenced by deleteFunc().

Here is the caller graph for this function:

◆ getNumberOfYCoords()

int interpolation::Interpolator3dGridTo1d::getNumberOfYCoords ( ) const
inlineinherited

Number of y coordinates in the grid

Definition at line 160 of file Interpolator3dGridTo1d.h.

References coordinates_m.

Referenced by deleteFunc().

Here is the caller graph for this function:

◆ getNumberOfZCoords()

int interpolation::Interpolator3dGridTo1d::getNumberOfZCoords ( ) const
inlineinherited

Number of z coordinates in the grid

Definition at line 164 of file Interpolator3dGridTo1d.h.

References coordinates_m.

◆ getPointDimension()

unsigned int interpolation::Interpolator3dGridTo1d::getPointDimension ( ) const
inlinevirtualinherited

Dimension of input points

Implements interpolation::VectorMap.

Definition at line 168 of file Interpolator3dGridTo1d.h.

◆ getValueDimension()

unsigned int interpolation::Interpolator3dGridTo1d::getValueDimension ( ) const
inlinevirtualinherited

Dimension of output values

Implements interpolation::VectorMap.

Definition at line 172 of file Interpolator3dGridTo1d.h.

◆ setAll()

void interpolation::Interpolator3dGridTo1d::setAll ( ThreeDGrid * grid,
double *** F )
inlineinherited

Set function and mesh data

Definition at line 211 of file Interpolator3dGridTo1d.h.

References setF(), and setGrid().

Referenced by Interpolator3dGridTo1d().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ setF()

void interpolation::Interpolator3dGridTo1d::setF ( double *** inF)
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().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ setGrid()

void interpolation::Interpolator3dGridTo1d::setGrid ( ThreeDGrid * grid)
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().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ setX()

void interpolation::Interpolator3dGridTo1d::setX ( int nCoords,
double * x )
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.

◆ setY()

void interpolation::Interpolator3dGridTo1d::setY ( int nCoords,
double * y )
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.

◆ setZ()

void interpolation::Interpolator3dGridTo1d::setZ ( int nCoords,
double * z )
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.

Member Data Documentation

◆ coordinates_m

◆ f_m


The documentation for this class was generated from the following files: