It is often needed to estimate the value of a function
at
certan point
based on the known values of the function
at a set of
node points
in the interval
. This process is called
interpolation if
or extrapolation if either
or
. One way to carry out these operations is to
approximate the function
by an nth degree polynomial:
data:image/s3,"s3://crabby-images/a1d92/a1d92703c1d9b2fffb4de6c06ae397f2c22fc13a" alt="$\displaystyle f(x)\approx P_n(x)=a_nx^n+a_{n-1}x^{n-1}+\cdots+a_2x^2+a_1x+a_0
=\sum_{j=0}^n a_jx^j$" |
(1) |
where the
coefficients
can be obtained based
on the
given points. Once
is available, any operation
applied to
, such as differentiation, intergration, and root
finding, can be carried out approximately based on
.
This is particulary useful if
is non-elementary and therefore
difficult to manipulate, or it is only available as a set of discrete
samples without a closed-form expression.
Specifically, to find the coefficients of
, we require it
to pass through all node points
,
i.e., the following
linear equations hold:
data:image/s3,"s3://crabby-images/1fa70/1fa701d335dfec53c87a910fde7adb648f0096b3" alt="$\displaystyle P_n(x_i)=\sum_{j=0}^n a_jx^j_i=f(x_i)=y_i,\;\;\;\;(i=0,\cdots,n)$" |
(2) |
Now the coefficients
can be found by solving these
linear equations, which can be expressed in matrix form as:
![$\displaystyle \left[ \begin{array}{ccccc}
1 & x_0 & x_0^2 & \cdots & x_0^n \\
...
...\left[\begin{array}{c}y_0\\ y_1\\ y_2\\ \vdots\\ y_n\end{array}\right]
={\bf y}$](img27.svg) |
(3) |
where
,
,
and
![$\displaystyle {\bf V}=\left[ \begin{array}{ccccc}
1 & x_0 & x_0^2 & \cdots & x_...
...vdots & \ddots & \vdots \\
1 & x_n & x_n^2 & \cdots & x_n^n
\end{array}\right]$](img30.svg) |
(4) |
is known as the Vandermonde matrix. Solving this linear
equation system, we get the coefficients
.
Here
polynomials
can be considered
as a set of polynomial basis functions that span the space of all
nth degree polynomials (which can also be spanned by any other
possible bases).
If the node points
are distinct, i.e.,
has a full rank and its inverse
exists, then the
solution of the system
is unique and
so is
.
In practice, however, this method is not widely used for two
reasons: (1) the high computational complexity
for
calculating
, and (2) matrix
becomes
more ill-conditioned as
increases. Instead, other methods
to be discussed in the following section are practically used.
The error of the polynomial interpolation is defined as
data:image/s3,"s3://crabby-images/9ea48/9ea4856c6ed180ce0f7110e627959b68994f11f5" alt="$\displaystyle R_n(x)=f(x)-P_n(x)$" |
(5) |
which is non-zero in general, except if
at which
. In other words, the error function
has
zeros at
, and can therefore be
written as
data:image/s3,"s3://crabby-images/220c4/220c4c394218fcabf1a0cd4d4d211ced980aba32" alt="$\displaystyle R_n(x)=u(x)\prod_{i=0}^n(x-x_i)=u(x) l(x)$" |
(6) |
where
is an unknown function and
is a polynomial
of degree
defined as
data:image/s3,"s3://crabby-images/4ae3b/4ae3bd545c0181bba0eb87e25edbb17ec82b5a3c" alt="$\displaystyle l(x)=\prod_{i=0}^n(x-x_i)$" |
(7) |
To find
, we construct another function
of variable
with any
as a parameter:
data:image/s3,"s3://crabby-images/4c6b4/4c6b42432f067b0dde5529f11dee7ef0c6ceeab3" alt="$\displaystyle F(t)=R_n(t)-u(x)\prod_{i=0}^n(t-x_i)=f(t)-P_n(t)-u(x)\prod_{i=0}^n(t-x_i)$" |
(8) |
which is zero when
:
data:image/s3,"s3://crabby-images/50718/507180c2c26440d5d2c563e69bf45742b7d127e4" alt="$\displaystyle F(x)=R_n(x)-u(x)\prod_{i=0}^n(x-x_i)=R_n(x)-R_n(x)=0$" |
(9) |
We therefore see that
has
zeros at
and
. According to Rolle's theorem, which states that the derivative
function
of any differentiable function
satisfying
must have at least a zero at some point
at which
,
has at least
zeros each between
two consecutive zeros of
,
has at least
zeros,
and
has at least one zero at some
:
The last equation is due to the fact that
and
are respectively an nth and (n+1)th degree polynomials of
. Solving the
above we get
data:image/s3,"s3://crabby-images/6638a/6638a96c9ea8e615fed4bd0adab780dbbfc1e62f" alt="$\displaystyle u(x)=\frac{f^{(n+1)}(\xi)}{(n+1)!}$" |
(11) |
Now the error function can be written as
data:image/s3,"s3://crabby-images/c8e8a/c8e8a5ef93826f3584b6dbccbe6fd4189705b5e9" alt="$\displaystyle R_n(x)=u(x)\prod_{i=0}^n(x-x_i)=\frac{f^{(n+1)}(\xi)}{(n+1)!}\,l(x)$" |
(12) |
where
is a point located anywhere between
and
dependending on
. The error can be quantitatively
measured by the 2-normal of
:
data:image/s3,"s3://crabby-images/f34d5/f34d564ca3ee3a4b01f915d3c6503336dc1a0d71" alt="$\displaystyle \epsilon=\vert\vert R_n(x)\vert\vert _2=\left(\int_a^b R^2_n(x)\,dx\right)^{1/2}$" |
(13) |
In particular, if
is a polynomial of degree
, then
, and it can be exactly interpolated by
. But
if
, the interpolation has a non-zero error term
. In
particular, if
is a polynomial of degree
, such as
, then
and the error term becomes:
data:image/s3,"s3://crabby-images/0b563/0b563088e625424b4e50aed1829119dcc41ce3f3" alt="$\displaystyle R_n(x)=\frac{f^{(n+1)}(\xi)}{(n+1)!}\,l(x)=l(x)$" |
(14) |
Due to the uniqueness of the polynomial interpolation, the error
analysis above also applies to all other methods to be considered in
the following sections, such as the Lagrange and Newton interpolations.
Example:
Approximate function
by a polynomial
of degree
, based on the following
node points:
We first find the Vandermonde matrix:
and get the coefficients:
and then the interpolating polynomial can be found as a weighted sum
of the first
power functions used as the basis functions to
span the polynomial space:
This interpolation polynomial
is plotted in the figure below,
in comparison to the orginal function
, together with the basis
polynomials, the power functions
. The error
can be approximated by a set of
discrete samples
of the function
and the interpolating polynomial
:
The Matlab code that implements this method is listed below.
function [v P]=PI(u,x,y)
% vectors x and y contain n+1 points and the corresponding function values
% vector u contains all discrete samples of the continuous argument of f(x)
n=length(x); % number of interpolating points
k=length(u); % number of discrete sample points
v=zeros(1,k); % polynomial interpolation
P=zeros(n,k); % power function basis polynomials
V=zeros(n); % Vandermonde matrix
for i=1:n
for j=1:n
V(i,j)=x(i)^(j-1);
end
end
c=inv(V)*y; % coefficients
for i=1:n
P(i,:)=u.^(i-1);
v=v+c(i)*P(i,:);
end
end