52 #ifndef __PCL_BicubicFilterInterpolation_h
53 #define __PCL_BicubicFilterInterpolation_h
58 #include <pcl/Diagnostics.h>
98 m_k31 = ( 12 - 9*m_B - 6*m_C)/6;
99 m_k21 = (-18 + 12*m_B + 6*m_C)/6;
100 m_k01 = ( 6 - 2*m_B )/6;
101 m_k32 = ( -m_B - 6*m_C)/6;
102 m_k22 = ( 6*m_B + 30*m_C)/6;
103 m_k12 = ( -12*m_B - 48*m_C)/6;
104 m_k02 = ( 8*m_B + 24*m_C)/6;
139 return (x < 1) ? m_k01 + x*x*(m_k21 + x*m_k31) :
140 m_k02 + x*(m_k12 + x*(m_k22 + x*m_k32));
161 return String().
Format(
"Cubic filter (B=%.6f, C=%.6f)", m_B, m_C );
174 double m_k31, m_k21, m_k01, m_k32, m_k22, m_k12, m_k02;
220 return "Mitchell-Netravali cubic filter";
270 return "Catmull-Rom spline filter";
320 return "Cubic B-spline filter";
333 #define m_width this->m_width
334 #define m_height this->m_height
335 #define m_fillBorder this->m_fillBorder
336 #define m_fillValue this->m_fillValue
337 #define m_data this->m_data
356 template <
typename T>
373 : m_rx(
Max( 1, rx ) )
374 , m_ry(
Max( 1, ry ) )
377 PCL_PRECONDITION( rx >= 1 )
378 PCL_PRECONDITION( ry >= 1 )
396 void Initialize(
const T* data,
int dataWidth,
int dataHeight )
override
400 if ( m_rx > m_width || m_ry > m_height )
402 m_rx =
Min( m_rx, m_width );
403 m_ry =
Min( m_ry, m_height );
421 PCL_PRECONDITION( m_data !=
nullptr )
422 PCL_PRECONDITION( m_width > 0 && m_height > 0 )
423 PCL_PRECONDITION( x >= 0 && x < m_width )
424 PCL_PRECONDITION( y >= 0 && y < m_height )
425 PCL_CHECK( m_rx >= 1 && m_rx <= m_width )
426 PCL_CHECK( m_ry >= 1 && m_ry <= m_height )
427 PCL_CHECK( !m_k.IsEmpty() )
435 int64 d =
int64( y0 - m_ry )*m_width + x0 - m_rx;
440 for (
int xi = -m_rx, c = 0; xi <= m_rx; ++xi, ++c )
441 wx += (m_k[c] = m_filter( m_sx*(xi - dx) ));
443 double sy = 0, wy = 0;
444 for (
int yi = -m_ry; yi <= m_ry; ++yi )
446 double ky = m_filter( m_sy*(yi - dy) );
458 sy += m_fillValue * ky;
462 p = m_data + (d - 2*
int64( m_width )*(y + 1));
464 else if ( y >= m_height )
468 sy += m_fillValue * ky;
472 p = m_data + (d -= m_width);
482 int x1 =
Min( x2, m_width-1 );
484 const double* kx = m_k.Begin();
490 sx += (m_fillBorder ? m_fillValue : double( *(p - (x + x)) )) * *kx++;
502 sx += (m_fillBorder ? m_fillValue : double( *--p )) * *kx++;
514 for (
int yi = -m_ry, r = 0; yi <= m_ry; ++yi, ++r )
515 wy += (m_k[r] = m_filter( m_sy*(yi - dy) ));
517 double sx = 0, wx = 0;
518 for (
int xi = -m_rx; xi <= m_rx; ++xi )
520 double kx = m_filter( m_sx*(xi - dx) );
532 sx += m_fillValue * kx;
536 p = m_data + (d - 2*(x + 1));
538 else if ( x >= m_width )
542 sx += m_fillValue * kx;
553 int y1 =
Min( y2, m_height-1 );
555 const double* ky = m_k.Begin();
561 sy += (m_fillBorder ? m_fillValue : double( *(p - (y + y)*m_width) )) * *ky++;
574 sy += (m_fillBorder ? m_fillValue : double( *(p -= m_width) )) * *ky++;
611 if ( rx != m_rx || ry != m_ry )
616 if ( this->data !=
nullptr )
618 if ( m_rx > m_width )
620 if ( m_ry > m_height )
655 m_sx = m_filter.
Width()/(m_rx + 0.5);
656 m_sy = m_filter.
Width()/(m_ry + 0.5);
657 m_k =
DVector( 1 + (
Max( m_rx, m_ry ) << 1) );
Bicubic filter interpolation algorithms.
const CubicFilter & Filter() const noexcept
int VerticalRadius() const noexcept
int HorizontalRadius() const noexcept
void Initialize(const T *data, int dataWidth, int dataHeight) override
void SetRadii(int rx, int ry)
BicubicFilterInterpolation(const BicubicFilterInterpolation &)=default
PCL_HOT_FUNCTION double operator()(double x, double y) const override
~BicubicFilterInterpolation() override
BicubicFilterInterpolation(int rx, int ry, const CubicFilter &filter)
void SetFilter(const CubicFilter &filter)
A generic interface to two-dimensional interpolation algorithms.
virtual void Initialize(const T *data, int width, int height)
Catmull-Rom spline filter.
CubicFilter * Clone() const override
~CatmullRomSplineFilter() override
String Description() const override
CatmullRomSplineFilter(const CatmullRomSplineFilter &)=default
CubicBSplineFilter(const CubicBSplineFilter &)=default
CubicFilter * Clone() const override
~CubicBSplineFilter() override
String Description() const override
Mitchell-Netravali parameterized cubic filters.
virtual CubicFilter * Clone() const
CubicFilter(double B, double C)
PCL_HOT_FUNCTION double operator()(double x) const noexcept
CubicFilter(const CubicFilter &)=default
virtual String Description() const
double Width() const noexcept
Generic vector of arbitrary length.
Mitchell-Netravali cubic filter with B=C=1/3.
CubicFilter * Clone() const override
MitchellNetravaliCubicFilter()
MitchellNetravaliCubicFilter(const MitchellNetravaliCubicFilter &)=default
~MitchellNetravaliCubicFilter() override
String Description() const override
String & Format(const_c_string8 fmt,...)
int RoundInt(T x) noexcept
constexpr const T & Min(const T &a, const T &b) noexcept
constexpr const T & Range(const T &x, const T &a, const T &b) noexcept
constexpr const T & Max(const T &a, const T &b) noexcept