#include <regularData2D.h>
Public Types | |
typedef ValueType | value_type |
typedef std::vector< ValueType >::iterator | iterator |
typedef std::vector< ValueType >::const_iterator | const_iterator |
typedef std::vector< ValueType >::reference | reference |
typedef std::vector< ValueType >::const_reference | const_reference |
typedef std::vector< ValueType >::pointer | pointer |
typedef std::vector< ValueType >::difference_type | difference_type |
typedef std::vector< ValueType >::size_type | size_type |
Type Definitions | |
typedef std::vector< ValueType > | VectorType |
The type containing an STL vector of the appropriate type. | |
typedef TVector2< float > | CoordinateType |
The coordinate type. | |
typedef std::vector< ValueType >::iterator | Iterator |
A mutable iterator. | |
typedef std::vector< ValueType >::const_iterator | ConstIterator |
A nonmutable iterator. | |
Public Member Functions | |
Constructors and Destructors | |
TRegularData2D () throw () | |
Default constructor. | |
TRegularData2D (const TRegularData2D< ValueType > &data) throw (Exception::OutOfMemory) | |
Copy constructor. | |
TRegularData2D (const CoordinateType &origin, const CoordinateType &dimension, const CoordinateType &spacing) throw (Exception::OutOfMemory) | |
Constructor. | |
TRegularData2D (const IndexType &size, const CoordinateType &origin=CoordinateType(0.0), const CoordinateType &dimension=CoordinateType(1.0)) throw (Exception::OutOfMemory) | |
virtual | ~TRegularData2D () throw () |
Destructor. | |
virtual void | clear () throw () |
Clear method. | |
Assignment | |
TRegularData2D & | operator= (const TRegularData2D< ValueType > &data) throw (Exception::OutOfMemory) |
Assignment operator. | |
Predicates | |
bool | operator== (const TRegularData2D< ValueType > &data) const throw () |
Equality operator. | |
bool | operator!= (const TRegularData2D< ValueType > &data) const throw () |
Inequality operator. | |
bool | empty () const throw () |
Empty predicate. | |
bool | isInside (const CoordinateType &x) const throw () |
Test if a given point is inside the grid. | |
Iterators | |
ConstIterator | begin () const throw () |
ConstIterator | end () const throw () |
Iterator | begin () throw () |
Iterator | end () throw () |
Accessors | |
size_type | size () const throw () |
size_type | max_size () const throw () |
void | swap (TRegularData2D< ValueType > &data) throw () |
const ValueType & | getData (const IndexType &index) const throw (Exception::OutOfGrid) |
Return a nonmutable reference to a specific data element. | |
ValueType & | getData (const IndexType &index) throw (Exception::OutOfGrid) |
Return a mutable reference to a specific data element. | |
const ValueType & | getData (Position index) const throw (Exception::OutOfGrid) |
Return a nonmutable reference to a specific data element. | |
ValueType & | getData (Position index) throw (Exception::OutOfGrid) |
Return a mutable reference to a specific data element. | |
const ValueType & | operator[] (const IndexType &index) const throw () |
Nonmutable random access operator. | |
ValueType & | operator[] (const IndexType &index) throw () |
Mutable random access operator. | |
const ValueType & | operator[] (Position index) const throw () |
Nonmutable random access operator. | |
ValueType & | operator[] (Position index) throw () |
Mutable random access operator. | |
ValueType | operator() (const CoordinateType &x) const throw () |
Function operator. | |
ValueType | getInterpolatedValue (const CoordinateType &x) const throw (Exception::OutOfGrid) |
Return the linearly interpolated value of the surrounding two grid points. | |
const ValueType & | getClosestValue (const CoordinateType &x) const throw (Exception::OutOfGrid) |
Return a nonmutable reference to the closest non-interpolated value. | |
ValueType & | getClosestValue (const CoordinateType &x) throw (Exception::OutOfGrid) |
Return a mutable reference to the closest non-interpolated value. | |
IndexType | getLowerIndex (const CoordinateType &v) const throw (Exception::OutOfGrid) |
Return the position of the grid point with coordinates lesser than the given vector. | |
IndexType | getClosestIndex (const CoordinateType &v) const throw (Exception::OutOfGrid) |
Return the position of the grid point closest to the given vector. | |
const IndexType & | getSize () const throw () |
Return the size of the grid. | |
const CoordinateType & | getOrigin () const throw () |
Return the origin of the data. | |
const CoordinateType & | getSpacing () const throw () |
Return the spacing of the data. | |
void | setOrigin (const CoordinateType &origin) throw () |
Set the origin of the data. | |
const CoordinateType & | getDimension () const throw () |
Return the dimension of the data. | |
void | setDimension (const CoordinateType &dimension) throw () |
Set the dimension of the data. | |
void | resize (const IndexType &new_size) throw (Exception::OutOfMemory) |
Resize the data. | |
void | rescale (const IndexType &new_size) throw (Exception::OutOfMemory) |
Rescale the data. | |
CoordinateType | getCoordinates (const IndexType &index) const throw (Exception::OutOfGrid) |
Return the exact coordinates of a grid point. | |
CoordinateType | getCoordinates (Position index) const throw (Exception::OutOfGrid) |
Return the exact coordinates of a grid point. | |
void | getEnclosingIndices (const CoordinateType &r, Position &ll, Position &lr, Position &ul, Position &ur) const throw (Exception::OutOfGrid) |
Return the indices of the grid points of the enclosing rectangle. | |
void | getEnclosingValues (const CoordinateType &r, ValueType &ll, ValueType &lr, ValueType &ul, ValueType &ur) const throw (Exception::OutOfGrid) |
Return the values at the grid points of the enclosing the spcified position. | |
void | binaryWrite (const String &filename) const throw (Exception::FileNotFound) |
Write the grid contents in a (non-portable) binary format. | |
void | binaryRead (const String &filename) throw (Exception::FileNotFound) |
Read the grid contents from a file written with binaryWrite. | |
Protected Attributes | |
VectorType | data_ |
The grid data. | |
CoordinateType | origin_ |
Origin of the grid (offset). | |
CoordinateType | dimension_ |
Dimension of the grid. | |
CoordinateType | spacing_ |
Grid spacing. | |
IndexType | size_ |
The dimensions in grid points. |
This class represents a two-dimensional array. An instance of ValueType will be created for each point of the grid upon instantiation of TRegularData2D.
Container
and Unary Function
requirements. Iteration is along the x-axis first, then along the y-axis.
|
Default constructor. Creates an empty TRegularData2D object. |
|
Constructor.
|
|
Destructor.
|
|
Read the grid contents from a file written with binaryWrite.
|
|
Write the grid contents in a (non-portable) binary format.
|
|
Clear method. Delete the grid contents and resize it to zero. Reimplemented in TFFT2D< ComplexTraits >. |
|
Return the position of the grid point closest to the given vector. If there are multiple grid points with equal distance, the grid point with the lowest indices in x, y direction is returned.
|
|
Return a mutable reference to the closest non-interpolated value.
This method first performs a range check for the argument |
|
Return a nonmutable reference to the closest non-interpolated value.
This method first performs a range check for the argument |
|
Return the exact coordinates of a grid point.
|
|
Return the exact coordinates of a grid point.
|
|
Return a mutable reference to a specific data element.
This is the range chacking version of |
|
Return a nonmutable reference to a specific data element.
This is the range chacking version of |
|
Return a mutable reference to a specific data element.
This is the range chacking version of |
|
Return a nonmutable reference to a specific data element.
This is the range chacking version of |
|
Return the dimension of the data.
The dimension represents the length of the data vector. Hence, the coordinate of the rightmost element, |
|
Return the indices of the grid points of the enclosing rectangle. This method calculates the grid rectangle that contains the given vector and returns the indices of the grid points forming this rectangle. The given point lies either in the rectangle or is the lower left front edge of the rectangle.
|
|
Return the values at the grid points of the enclosing the spcified position.
|
|
Return the linearly interpolated value of the surrounding two grid points.
This method first performs a range check for the argument |
|
Return the position of the grid point with coordinates lesser than the given vector.
|
|
Return the origin of the data.
The origin represents the coordinate of the very first (lower left) element, i.e. |
|
Return the size of the grid. This method yields the number of grid points in x- and y-direction. Use size to obtain the total number of points in the grid. |
|
Return the spacing of the data. The spacing corresponds to the distance between two adjacent data elements. |
|
Function operator.
This operator allows the use of a TRegularData1D instance as a unary function. As required by the STL |
|
Assignment operator. Copy the data, the origin, and the dimension (spacing is copied implicitly as well). |
|
Equality operator. Two grids are equal if they have the same number of points in all two dimensions, same origin, spacing and the data fields are equal. |
|
Mutable random access operator.
|
|
Nonmutable random access operator.
|
|
Mutable random access operator.
|
|
Nonmutable random access operator.
|
|
Rescale the data.
Keep the current boundaries of the data and reinterpolate the data to reflect the new size. To create a data set of
|
|
Resize the data.
If
|
|
Set the dimension of the data. This will affect neither the origin of the data, nor the number of elements stored (in contrast to resize() ). It will just store the appropriate scling factor and affect the spacing. |