PCL
|
Bicubic spline interpolation algorithm. More...
#include <BicubicInterpolation.h>
Public Member Functions | |
BicubicSplineInterpolation (const BicubicSplineInterpolation &)=default | |
BicubicSplineInterpolation (float clamp=__PCL_BICUBIC_SPLINE_CLAMPING_THRESHOLD) | |
~BicubicSplineInterpolation () override | |
float | ClampingThreshold () const noexcept |
double | InterpolateVector (const double c[], double dx) const noexcept |
void | InterpolateX (double fx[], double x, double y) const noexcept |
void | InterpolateY (double fy[], double x, double y) const noexcept |
double | operator() (double x, double y) const override |
void | SetClampingThreshold (float c) noexcept |
Public Member Functions inherited from pcl::BicubicInterpolationBase< T > | |
BicubicInterpolationBase ()=default | |
BicubicInterpolationBase (const BicubicInterpolationBase &)=default | |
Public Member Functions inherited from pcl::BidimensionalInterpolation< T > | |
BidimensionalInterpolation ()=default | |
BidimensionalInterpolation (const BidimensionalInterpolation &)=default | |
virtual | ~BidimensionalInterpolation () |
const T * | BeingInterpolated () const |
double | BorderFillValue () const |
virtual void | Clear () |
void | DisableBorderFilling (bool disable=true) |
void | EnableBorderFilling (bool enable=true) |
int | Height () const |
virtual void | Initialize (const T *data, int width, int height) |
bool | IsBorderFillingEnabled () const |
void | SetBorderFillValue (double v) |
int | Width () const |
Bicubic interpolation algorithms interpolate from the nearest sixteen mapped source data items. Our implementation uses the following cubic spline function as a separable filter to perform a convolution interpolation:
f(x) = (a+2)*x^3 - (a+3)*x^2 + 1 for 0 <= x <= 1 f(x) = a*x^3 - 5*a*x^2 + 8*a*x - 4*a for 1 < x <= 2 f(x) = 0 otherwise
Reference: Keys, R. G. (1981), Cubic Convolution Interpolation for Digital Image Processing, IEEE Trans. Acoustics, Speech & Signal Proc., Vol. 29, pp. 1153-1160.
The a constant parameter of the cubic spline (-1 <= a < 0) controls the depth of the negative lobes of the interpolation function. In this implementation we have set a fixed value a=-1/2.
Our implementation includes an automatic linear clamping mechanism to avoid discontinuity problems when interpolating linear images. The cubic spline function has negative lobes that can cause undershoot (aka ringing) artifacts when they fall over bright pixels. This happens frequently with linear CCD images. See the documentation for the BicubicSplineInterpolation::SetClampingThreshold( float ) function for a more detailed description of the linear clamping mechanism.
Definition at line 379 of file BicubicInterpolation.h.
|
inline |
Constructs a BicubicSplineInterpolation instance.
The optional clamp parameter defines a threshold to trigger the linear clamping mechanism. See the documentation for the SetClampingThreshold( float ) function for a detailed description of the automatic linear clamping mechanism. The default value of clamp is 0.3, which is appropriate for most linear images.
Definition at line 392 of file BicubicInterpolation.h.
|
default |
Copy constructor.
|
inlineoverride |
Virtual destructor.
Definition at line 406 of file BicubicInterpolation.h.
|
inlinenoexcept |
Returns the current linear clamping threshold for this interpolation object.
See the documentation for SetClampingThreshold( float ) for a detailed description of the automatic linear clamping mechanism.
Definition at line 548 of file BicubicInterpolation.h.
|
inlinenoexcept |
Vector interpolation.
c | Address of the first element of a vector of four data points. |
dx | Interpolation point in the range [0,+1[. A value of zero corresponds to the second element in the f vector. |
This function interpolates four neighbor rows or columns by direct convolution with the cubic spline function. The four elements of the c vector can be raw data points, to use cubic spline interpolation in one dimension, or they can be interpolated rows or columns from an arbitrary 2-D matrix. For example, c can be generated by a previous call to InterpolateX() or InterpolateY(), respectively to provide source interpolated rows or columns, or by equivalent functions from a different separable cubic interpolation algorithm. This is useful to mix cubic spline interpolation with other interpolation algorithms, which allows for flexible interpolation schemes.
Definition at line 534 of file BicubicInterpolation.h.
|
inlinenoexcept |
Horizontal interpolation.
x,y | Coordinates of the interpolation point (horizontal, vertical). | |
[out] | fx | Address of the first element of a vector where the four interpolated X-values will be stored. |
This function interpolates horizontally the four neighbor rows for the specified x, y coordinates. This is useful when this interpolation algorithm is being used to interpolate an image on the horizontal axis exclusively.
Definition at line 459 of file BicubicInterpolation.h.
|
inlinenoexcept |
Vertical interpolation.
x,y | Coordinates of the interpolation point (horizontal, vertical). | |
[out] | fy | Address of the first element of a vector where the four interpolated Y-values will be stored. |
This function interpolates vertically the four neighbor columns for the specified x, y coordinates. This is useful when this interpolation algorithm is being used to interpolate an image on the vertical axis exclusively.
Definition at line 494 of file BicubicInterpolation.h.
|
inlineoverridevirtual |
Returns an interpolated value at {x,y} location.
x,y | Coordinates of the interpolation point (horizontal, vertical). |
This function performs a two-dimensional interpolation via a convolution with the separable cubic spline filter.
Implements pcl::BidimensionalInterpolation< T >.
Definition at line 419 of file BicubicInterpolation.h.
|
inlinenoexcept |
Defines a threshold to trigger the linear clamping mechanism. The clamping mechanism automatically switches to linear interpolation when the differences between neighbor pixels are so large that the cubic interpolation function may cause ringing artifacts. Ringing occurs when the negative lobes of the cubic spline interpolation function fall over isolated bright source pixels or bright edges. For example, ringing problems happen frequently around stars in linear CCD images. For nonlinear images, linear clamping is almost never necessary, as in nonlinear images (e.g., stretched deep-sky images, or diurnal images) there are normally no such large variations between neighbor pixels.
Linear clamping works on a per-row or per-column basis within the interpolation neighborhood of 16 pixels. This means that when the clamping mechanism selects linear interpolation, it restricts its use to the affected (by too strong variations) row or column, without changing the bicubic interpolation scheme as a whole. This ensures artifact-free interpolated images without degrading the overall performance of bicubic spline interpolation.
The specified clamping threshold clamp must be in the [0,1] range. Lower values cause a more aggressive deringing effect.
Definition at line 576 of file BicubicInterpolation.h.
References pcl::Range().