Bicubic interpolation

![[0,3] \times [0,3]](../I/m/28223bd4180e036428b2296cc98c9642.png) consisting of 9 unit squares patched together. Bicubic interpolation as per MATLAB's implementation. Colour indicates function value. The black dots are the locations of the prescribed data being interpolated. Note how the color samples are not radially symmetric.
 consisting of 9 unit squares patched together. Bicubic interpolation as per MATLAB's implementation. Colour indicates function value. The black dots are the locations of the prescribed data being interpolated. Note how the color samples are not radially symmetric.

In mathematics, bicubic interpolation is an extension of cubic interpolation for interpolating data points on a two dimensional regular grid. The interpolated surface is smoother than corresponding surfaces obtained by bilinear interpolation or nearest-neighbor interpolation. Bicubic interpolation can be accomplished using either Lagrange polynomials, cubic splines, or cubic convolution algorithm.
In image processing, bicubic interpolation is often chosen over bilinear interpolation or nearest neighbor in image resampling, when speed is not an issue. In contrast to bilinear interpolation, which only takes 4 pixels (2×2) into account, bicubic interpolation considers 16 pixels (4×4). Images resampled with bicubic interpolation are smoother and have fewer interpolation artifacts.
Suppose the function values  and the derivatives
 and the derivatives  ,
,  and
 and  are known at the four corners
 are known at the four corners  ,
,  ,
,  , and
, and  of the unit square. The interpolated surface can then be written
 of the unit square. The interpolated surface can then be written
The interpolation problem consists of determining the 16 coefficients  .
Matching
.
Matching  with the function values yields four equations,
 with the function values yields four equations,
Likewise, eight equations for the derivatives in the  -direction and the
-direction and the  -direction
-direction
And four equations for the cross derivative  .
.
where the expressions above have used the following identities,
 
 
 . .
This procedure yields a surface  on the unit square
 on the unit square ![[0,1] \times [0,1]](../I/m/38c7b34812cb087f3562f9ebc984e3c8.png) which is continuous and with continuous derivatives. Bicubic interpolation on an arbitrarily sized regular grid can then be accomplished by patching together such bicubic surfaces, ensuring that the derivatives match on the boundaries.
 which is continuous and with continuous derivatives. Bicubic interpolation on an arbitrarily sized regular grid can then be accomplished by patching together such bicubic surfaces, ensuring that the derivatives match on the boundaries.
Grouping the unknown parameters  in a vector,
 in a vector,
and letting
![x=\left[\begin{smallmatrix}f(0,0)&f(1,0)&f(0,1)&f(1,1)&f_x(0,0)&f_x(1,0)&f_x(0,1)&f_x(1,1)&f_y(0,0)&f_y(1,0)&f_y(0,1)&f_y(1,1)&f_{xy}(0,0)&f_{xy}(1,0)&f_{xy}(0,1)&f_{xy}(1,1)\end{smallmatrix}\right]^T](../I/m/9c3e51bfcb0a7ee1d142a2ad577b2fce.png) , ,
the above system of equations can be reformulated into a matrix for the linear equation  .
.  
Inverting the matrix gives the more useful linear equation  which allows
 which allows  to be calculated quickly and easily, where:
 to be calculated quickly and easily, where:
![A^{-1}=\left[\begin{smallmatrix}
 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 -3 & 3 & 0 & 0 & -2 & -1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 2 & -2 & 0 & 0 & 1 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 0 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & -3 & 3 & 0 & 0 & -2 & -1 & 0 & 0 \\
 0 & 0 & 0 & 0 & 0 & 0 & 0 & 0 & 2 & -2 & 0 & 0 & 1 & 1 & 0 & 0 \\
 -3 & 0 & 3 & 0 & 0 & 0 & 0 & 0 & -2 & 0 & -1 & 0 & 0 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & -3 & 0 & 3 & 0 & 0 & 0 & 0 & 0 & -2 & 0 & -1 & 0 \\
 9 & -9 & -9 & 9 & 6 & 3 & -6 & -3 & 6 & -6 & 3 & -3 & 4 & 2 & 2 & 1 \\
 -6 & 6 & 6 & -6 & -3 & -3 & 3 & 3 & -4 & 4 & -2 & 2 & -2 & -2 & -1 & -1 \\
 2 & 0 & -2 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 0 & 0 & 0 & 0 & 0 \\
 0 & 0 & 0 & 0 & 2 & 0 & -2 & 0 & 0 & 0 & 0 & 0 & 1 & 0 & 1 & 0 \\
 -6 & 6 & 6 & -6 & -4 & -2 & 4 & 2 & -3 & 3 & -3 & 3 & -2 & -1 & -2 & -1 \\
 4 & -4 & -4 & 4 & 2 & 2 & -2 & -2 & 2 & -2 & 2 & -2 & 1 & 1 & 1 & 1
\end{smallmatrix}\right]](../I/m/14242c2a47ab87a56e4a2b592a5410a5.png) . .
There can be another concise matrix form for 16 coefficients
 , or , or
 where
 where
 .
.
Finding derivatives from function values
If the derivatives are unknown, they are typically approximated from the function values at points neighbouring the corners of the unit square, e.g. using finite differences.
To find either of the single derivatives,  or
 or  , using that method, find the slope between the two surrounding points in the appropriate axis. For example, to calculate
, using that method, find the slope between the two surrounding points in the appropriate axis. For example, to calculate  for one of the points, find
 for one of the points, find  for the points to the left and right of the target point and calculate their slope, and similarly for
 for the points to the left and right of the target point and calculate their slope, and similarly for  .
.
To find the cross derivative,  , take the derivative in both axes, one at a time. For example, one can first use the
, take the derivative in both axes, one at a time. For example, one can first use the  procedure to find the
 procedure to find the  derivatives of the points above and below the target point, then use the
 derivatives of the points above and below the target point, then use the  procedure on those values (rather than, as usual, the values of
 procedure on those values (rather than, as usual, the values of  for those points) to obtain the value of
 for those points) to obtain the value of  for the target point.  (Or one can do it in the opposite direction, first calculating
 for the target point.  (Or one can do it in the opposite direction, first calculating  and then
 and then  off of those.  The two give equivalent results.)
 off of those.  The two give equivalent results.)
At the edges of the dataset, when one is missing some of the surrounding points, the missing points can be approximated by a number of methods. A simple and common method is to assume that the slope from the existing point to the target point continues without further change, and using this to calculate a hypothetical value for the missing point.
Bicubic convolution algorithm
Bicubic spline interpolation requires the solution of the linear system described above for each grid cell. An interpolator with similar properties can be obtained by applying a convolution with the following kernel in both dimensions:
where  is usually set to -0.5 or -0.75. Note that
 is usually set to -0.5 or -0.75. Note that  and
 and  for all nonzero integers
 for all nonzero integers  .
.
This approach was proposed by Keys who showed that  (which corresponds to cubic Hermite spline) produces third-order convergence with respect to the original function.[1]
 (which corresponds to cubic Hermite spline) produces third-order convergence with respect to the original function.[1]
If we use the matrix notation for the common case  , we can express the equation in a more friendly manner:
, we can express the equation in a more friendly manner:
for  between 0 and 1 for one dimension. Note that for 1-dimensional cubic convolution interpolation 4 sample points are required. For each inquiry two samples are located on its left and two samples on the right. These points are indexed from -1 to 2 in this text. The distance from the point indexed with 0 to the inquiry point is denoted by
 between 0 and 1 for one dimension. Note that for 1-dimensional cubic convolution interpolation 4 sample points are required. For each inquiry two samples are located on its left and two samples on the right. These points are indexed from -1 to 2 in this text. The distance from the point indexed with 0 to the inquiry point is denoted by  here.
 here.
For two dimensions first applied once in  and again in
 and again in  :
:
Use in computer graphics

The bicubic algorithm is frequently used for scaling images and video for display (see bitmap resampling). It preserves fine detail better than the common bilinear algorithm.
However, due to the negative lobes on the kernel, it causes overshoot (haloing). This can cause clipping, and is an artifact (see also ringing artifacts), but it increases acutance (apparent sharpness), and can be desirable.
See also
- Spatial anti-aliasing
- Bézier surface
- Bilinear interpolation
- Cubic Hermite spline, the one-dimensional analogue of bicubic spline
- Lanczos resampling
- Natural neighbor interpolation
- Sinc filter
- Spline interpolation
- Tricubic interpolation
- Directional Cubic Convolution Interpolation
References
- ↑ R. Keys, (1981). "Cubic convolution interpolation for digital image processing". IEEE Transactions on Acoustics, Speech, and Signal Processing 29 (6): 1153–1160. doi:10.1109/TASSP.1981.1163711.
External links
- Application of interpolation to elevation samples
- Interpolation theory
- Explanation and Java/C++ implementation of (bi)cubic interpolation
- Excel Worksheet Function for Bicubic Lagrange Interpolation

















![\alpha=\left[\begin{smallmatrix}a_{00}&a_{10}&a_{20}&a_{30}&a_{01}&a_{11}&a_{21}&a_{31}&a_{02}&a_{12}&a_{22}&a_{32}&a_{03}&a_{13}&a_{23}&a_{33}\end{smallmatrix}\right]^T](../I/m/d5e1e201af7911fbc8e9114ecdd3dd7f.png)






