In Polynomial interpolation and The interpolation problem we encountered polynomial interpolation for the n + 1 n+1 n + 1 data points ( t 0 , y 0 ) , … , ( t n , y n ) (t_0,y_0),\ldots, (t_n,y_n) ( t 0 , y 0 ) , … , ( t n , y n ) . As before, we use t i t_i t i to denote interpolation or data nodes, and x x x to denote the independent variable. Remember that while our mathematical notation starts indexing the points at zero, in our codes we have to shift the indices up by 1.
Theoretically, we can always construct an interpolating polynomial, and the result is unique among polynomials whose degree is less than n + 1 n+1 n + 1 .
If the nodes t 0 , … , t n t_0,\dots,t_n t 0 , … , t n are all distinct, there exists a unique polynomial p p p of degree at most n n n that satisfies p ( t k ) = y k p(t_k)=y_k p ( t k ) = y k for all k = 0 , … , n k=0,\dots,n k = 0 , … , n .
We defer the existence part to Equation (9.1.4) . As for uniqueness, if p p p and q q q are two interpolating polynomials, then p − q p-q p − q is a polynomial of degree at most n n n that is zero at the n + 1 n+1 n + 1 points t 0 , … , t n t_0,\dots,t_n t 0 , … , t n . By the Fundamental Theorem of Algebra, which states that a k k k th degree polynomial has no more than k k k roots, we conclude that p − q ≡ 0 p-q\equiv 0 p − q ≡ 0 , so p = q p=q p = q .
In our earlier encounters with polynomial interpolation, we found the interpolant by solving a linear system of equations with a Vandermonde matrix. The first step was to express the polynomial in the natural monomial basis 1 , x , x 2 , … 1,x,x^2,\ldots 1 , x , x 2 , … . However, as we saw in Piecewise linear interpolation , no basis is more convenient than a cardinal basis , in which each member is one at a single node and zero at all of the other nodes.
It is surprisingly straightforward to construct a cardinal basis for global polynomial interpolation. By definition, each member ℓ k \ell_{k} ℓ k of the basis, for k = 0 , … , n k=0,\ldots,n k = 0 , … , n , is an n n n th degree polynomial satisfying the cardinality conditions
ℓ k ( t j ) = { 1 if j = k , 0 otherwise. \ell_{k}(t_j) = \begin{cases}
1 &\text{if $j=k$,}\\
0 & \text{otherwise.}
\end{cases} ℓ k ( t j ) = { 1 0 if j = k , otherwise. Recall that any polynomial of degree n n n can be expressed as
c ( x − r 1 ) ( x − r 2 ) … ( x − r n ) = c ∏ k = 1 n ( x − r k ) , c(x-r_1)(x-r_2)\dots(x-r_n) = c\prod_{k=1}^n(x-r_k), c ( x − r 1 ) ( x − r 2 ) … ( x − r n ) = c k = 1 ∏ n ( x − r k ) , where r 1 , … , r n r_1,\dots,r_n r 1 , … , r n are the roots of the polynomial and c c c is a constant. The conditions (9.1.1) give all n n n roots of ℓ k \ell_{k} ℓ k , and the normalization ℓ k ( t k ) = 1 \ell_{k}(t_k)=1 ℓ k ( t k ) = 1 tells us how to find c c c .
Definition 9.1.1 (Lagrange cardinal polynomial)
Given distinct nodes t 0 , … , t n t_0,\ldots,t_n t 0 , … , t n , the polynomial
ℓ k ( x ) = ( x − t 0 ) … ( x − t k − 1 ) ( x − t k + 1 ) … ( x − t n ) ( t k − t 0 ) … ( t k − t k − 1 ) ( t k − t k + 1 ) … ( t k − t n ) = ∏ i = 0 i ≠ k n ( x − t i ) ( t k − t i ) \begin{split}
\ell_{k}(x) & = \frac{(x-t_0)\dots(x-t_{k-1})(x-t_{k+1})\dots(x-t_n)}{(t_k-t_0)\dots(t_k-t_{k-1})(t_k-t_{k+1})\dots(t_k-t_n)} \\[1mm]
&= \prod_{\substack{i=0\\i\ne k}}^n \frac{(x-t_i)}{(t_k-t_i)}
\end{split} ℓ k ( x ) = ( t k − t 0 ) … ( t k − t k − 1 ) ( t k − t k + 1 ) … ( t k − t n ) ( x − t 0 ) … ( x − t k − 1 ) ( x − t k + 1 ) … ( x − t n ) = i = 0 i = k ∏ n ( t k − t i ) ( x − t i ) is of degree at most n n n and satisfies the cardinality conditions (9.1.1) .
Example 9.1.1 (Lagrange cardinal polynomials)
Example 9.1.1 Here is a vector of nodes.
t = [ 1, 1.5, 2, 2.25, 2.75, 3 ]
n = length(t) - 1;
Let’s apply the definition of the cardinal Lagrange polynomial for k = 2 k=2 k = 2 . First we define a polynomial q q q that is zero at all the nodes except i = k i=k i = k . Then ℓ 2 \ell_2 ℓ 2 is found by normalizing q q q by q ( t k ) q(t_k) q ( t k ) .
Character ℓ is typed as \ell
Tab .
k = 2
q(x) = prod(x - t[i] for i in [0:k-1; k+1:n] .+ 1)
ℓₖ(x) = q(x) / q(t[k+1]);
A plot confirms the cardinal property of the result.
using Plots
plot(ℓₖ, 1, 3)
y = zeros(n+1); y[k+1] = 1
scatter!(t, y, color=:black,
xaxis=(L"x"), yaxis=(L"\ell_2(x)"),
title="Lagrange cardinal function")
Observe that ℓ k \ell_k ℓ k is not between zero and one everywhere, unlike a hat function.
Example 9.1.1 Here is a vector of nodes.
t = [ 1, 1.5, 2, 2.25, 2.75, 3 ];
n = 5; k = 2;
not_k = [0:k-1 k+1:n]; % all except the kth node
Let’s apply the definition of the cardinal Lagrange polynomial for k = 2 k=2 k = 2 . First we define a polynomial q q q that is zero at all the nodes except i = k i=k i = k . Then ℓ 2 \ell_2 ℓ 2 is found by normalizing q q q by q ( t k ) q(t_k) q ( t k ) .
Whenever we index into the node vector t
, we have to add 1 since the mathematical index starts at zero.
q = @(x) prod(x - t(not_k + 1));
ell_k = @(x) q(x) ./ q(t(k + 1));
A plot confirms the cardinal property of the result.
clf
fplot(ell_k, [1, 3])
hold on, grid on
plot(t(not_k + 1), 0 * t(not_k + 1), 'o')
plot(t(k + 1), 1, 'o')
xlabel('x'), ylabel('\ell_2(x)')
title('Lagrange cardinal function')
Warning: Function behaves unexpectedly on array inputs. To improve performance, properly vectorize your function to return an output with the same size and shape as the input arguments.
Observe that ℓ k \ell_k ℓ k is not between zero and one everywhere, unlike a hat function.
Example 9.1.1 Here is a vector of nodes.
t = array([1, 1.5, 2, 2.25, 2.75, 3])
n = 5
Let’s apply the definition of the cardinal Lagrange polynomial for k = 2 k=2 k = 2 . First we define a polynomial q q q that is zero at all the nodes except i = k i=k i = k . Then ℓ 2 \ell_2 ℓ 2 is found by normalizing q q q by q ( t k ) q(t_k) q ( t k ) .
k = 2
q = lambda x: prod([x - t[i] for i in range(n + 1) if i != k])
ell_k = lambda x: q(x) / q(t[k])
A plot confirms the cardinal property of the result.
x = linspace(1, 3, 500)
plot(x, [ell_k(xx) for xx in x])
y = zeros(n+1)
y[k] = 1
plot(t, y, "ko")
xlabel("$x$"), ylabel("$\\ell_2(x)$")
title(("Lagrange cardinal function"));
Observe that ℓ k \ell_k ℓ k is not between zero and one everywhere, unlike a hat function.
Because they are a cardinal basis, the Lagrange polynomials lead to a simple expression for the polynomial interpolating the ( t k , y k ) (t_k,y_k) ( t k , y k ) points.
Theorem 9.1.2 (Lagrange interpolation formula)
Given points ( t k , y k ) (t_k,y_k) ( t k , y k ) for k = 0 , … , n k=0,\ldots,n k = 0 , … , n with all the t k t_k t k distinct, the unique polynomial of degree n n n or less that interpolates the points is
p ( x ) = ∑ k = 0 n y k ℓ k ( x ) . p(x) = \sum_{k=0}^n y_k \ell_k(x). p ( x ) = k = 0 ∑ n y k ℓ k ( x ) . At this point we can say that we have completed the proof of Theorem 9.1.1 .
We construct the Lagrange interpolating polynomials of degrees n = 1 n=1 n = 1 and 2 to interpolate samples of f ( x ) = tan ( x ) f(x) = \tan (x) f ( x ) = tan ( x ) . For n = 1 n=1 n = 1 , we use t 0 = 0 t_0= 0 t 0 = 0 and t 1 = π / 3 t_1 = \pi/3 t 1 = π /3 . The Lagrange formula then gives
P 1 ( x ) = y 0 ℓ 0 ( x ) + y 1 ℓ 1 ( x ) = y 0 x − t 1 t 0 − t 1 + y 1 x − t 0 t 1 − t 0 = 0 ⋅ x − π 3 0 − π 3 + 3 ⋅ x − 0 π 3 − 0 = 3 3 π x . \begin{align*}
P_1(x) & = y_0 \ell_0(x) + y_1 \ell_1(x) \\
& = y_0 \frac{x-t_1}{t_0-t_1} + y_1 \frac{x-t_0}{t_1-t_0} \\
& = 0 \cdot \frac{x-\frac{\pi}{3}}{0-\frac{\pi}{3}} + \sqrt{3} \cdot \frac{x-0}{\frac{\pi}{3}-0} \\
& = \frac{3 \sqrt{3}}{\pi} x.
\end{align*} P 1 ( x ) = y 0 ℓ 0 ( x ) + y 1 ℓ 1 ( x ) = y 0 t 0 − t 1 x − t 1 + y 1 t 1 − t 0 x − t 0 = 0 ⋅ 0 − 3 π x − 3 π + 3 ⋅ 3 π − 0 x − 0 = π 3 3 x . This is the unique linear function passing through ( 0 , 0 ) (0,0) ( 0 , 0 ) and ( π / 3 , 3 ) (\pi/3,\sqrt{3}) ( π /3 , 3 ) .
For n = 2 n=2 n = 2 , we use t 0 = 0 t_0= 0 t 0 = 0 , 1 = π / 6 _1 = \pi/6 1 = π /6 and t 2 = π / 3 t_2 = \pi/3 t 2 = π /3 . We now have
P 2 ( x ) = y 0 ℓ 0 ( x ) + y 1 ℓ 1 ( x ) + y 2 ℓ 2 ( x ) = y 0 ( x − t 1 ) ( x − t 2 ) ( t 0 − t 1 ) ( t 0 − t 2 ) + y 1 ( x − t 0 ) ( x − t 2 ) ( t 1 − t 0 ) ( t 1 − t 2 ) + y 2 ( x − t 0 ) ( x − t 1 ) ( t 2 − t 0 ) ( t 2 − t 1 ) = 0 + 1 3 ( x − 0 ) ( x − π 3 ) ( π 6 − 0 ) ( π 6 − π 3 ) + 3 ( x − 0 ) ( x − π 6 ) ( π 3 − 0 ) ( π 3 − π 6 ) = 6 3 π 2 x 2 + 3 π x . \begin{align*}
P_2(x) & = y_0 \ell_0(x) + y_1 \ell_1(x) + y_2 \ell_2(x) \\
& = y_0 \frac{(x-t_1)(x-t_2)}{(t_0-t_1)(t_0-t_2)} +
y_1 \frac{(x-t_0)(x-t_2)}{(t_1-t_0)(t_1-t_2)} +
y_2 \frac{(x-t_0)(x-t_1)}{(t_2-t_0)(t_2-t_1)} \\
& = 0
+ \frac{1}{\sqrt{3}} \frac{\left(x-0\right)\left(x-\frac{\pi}{3}\right)}
{\left(\frac{\pi}{6}-0\right)\left(\frac{\pi}{6}-\frac{\pi}{3}\right)}
+ \sqrt{3} \frac{\left(x-0\right)\left(x-\frac{\pi}{6}\right)}
{\left(\frac{\pi}{3}-0\right)\left(\frac{\pi}{3}-\frac{\pi}{6}\right)}
= \frac{6\sqrt{3}}{\pi^2}x^2 + \frac{\sqrt{3}}{\pi} x.
\end{align*} P 2 ( x ) = y 0 ℓ 0 ( x ) + y 1 ℓ 1 ( x ) + y 2 ℓ 2 ( x ) = y 0 ( t 0 − t 1 ) ( t 0 − t 2 ) ( x − t 1 ) ( x − t 2 ) + y 1 ( t 1 − t 0 ) ( t 1 − t 2 ) ( x − t 0 ) ( x − t 2 ) + y 2 ( t 2 − t 0 ) ( t 2 − t 1 ) ( x − t 0 ) ( x − t 1 ) = 0 + 3 1 ( 6 π − 0 ) ( 6 π − 3 π ) ( x − 0 ) ( x − 3 π ) + 3 ( 3 π − 0 ) ( 3 π − 6 π ) ( x − 0 ) ( x − 6 π ) = π 2 6 3 x 2 + π 3 x . In addition to existence, uniqueness, and the constructive Lagrange formula, we have a useful formula for the error in a polynomial interpolant when the data are samples of a smooth function. We will refer to the following definition.
Definition 9.1.2 (Error indicator function)
The error indicator function for a set of distinct nodes t 0 , … , t n t_0,\ldots,t_n t 0 , … , t n is
Φ ( x ) = ∏ i = 0 n ( x − t i ) . \Phi(x) = \prod_{i=0}^n (x-t_i). Φ ( x ) = i = 0 ∏ n ( x − t i ) . Theorem 9.1.3 (Polynomial interpolation error)
Let t 0 , … , t n t_0,\dots,t_n t 0 , … , t n be distinct points in [ a , b ] [a,b] [ a , b ] , and suppose f f f has at least n + 1 n+1 n + 1 continuous derivatives in that interval. Let p ( x ) p(x) p ( x ) be the unique polynomial of degree at most n n n interpolating f f f at t 0 , … , t n t_0,\dots,t_n t 0 , … , t n . Then for each x ∈ [ a , b ] x\in[a,b] x ∈ [ a , b ] , there exists a number ξ ( x ) ∈ ( a , b ) \xi(x)\in(a,b) ξ ( x ) ∈ ( a , b ) such that
f ( x ) − p ( x ) = f ( n + 1 ) ( ξ ) ( n + 1 ) ! Φ ( x ) , f(x) - p(x) = \frac{f^{(n+1)}(\xi)}{(n+1)!} \Phi(x), f ( x ) − p ( x ) = ( n + 1 )! f ( n + 1 ) ( ξ ) Φ ( x ) , with Φ given in (9.1.7) .
If x = t i x=t_i x = t i for some i i i , the statement of the theorem is trivially true. Otherwise, we define a new function g ( s ) g(s) g ( s ) by
g x ( s ) = Φ ( s ) [ f ( x ) − p ( x ) ] − Φ ( x ) [ f ( s ) − p ( s ) ] . g_x(s) = \Phi(s)[f(x)-p(x)] - \Phi(x)[f(s)-p(s)]. g x ( s ) = Φ ( s ) [ f ( x ) − p ( x )] − Φ ( x ) [ f ( s ) − p ( s )] . Note that x x x is now arbitrary but fixed. Clearly g x ( t i ) = 0 g_x(t_i)=0 g x ( t i ) = 0 for each i = 0 , … , n i=0,\dots,n i = 0 , … , n , because both Φ and the error f − p f-p f − p have that property. Also, g x ( x ) = 0 g_x(x)=0 g x ( x ) = 0 . So g x g_x g x has at least n + 2 n+2 n + 2 zeros in [ a , b ] [a,b] [ a , b ] . This is possible only if g x g_x g x has at least n + 1 n+1 n + 1 local minima in ( a , b ) (a,b) ( a , b ) ; i.e., g x ′ g_x' g x ′ has at least n + 1 n+1 n + 1 zeros. But that implies that g x ′ ′ g_x'' g x ′′ must have at least n n n zeros, etc. Eventually we conclude that g x ( n + 1 ) g_x^{(n+1)} g x ( n + 1 ) has at least one zero in ( a , b ) (a,b) ( a , b ) . Let ξ ( x ) \xi(x) ξ ( x ) be such a zero.
Observe that Φ is a monic polynomial (i.e., its leading coefficient is 1) of degree n + 1 n+1 n + 1 . Hence Φ ( n + 1 ) ( t ) = ( n + 1 ) ! \Phi^{(n+1)}(t)=(n+1)! Φ ( n + 1 ) ( t ) = ( n + 1 )! . Since p p p has degree at most n n n , p ( n + 1 ) = 0 p^{(n+1)}=0 p ( n + 1 ) = 0 . Finally, we write
0 = g x ( n + 1 ) ( ξ ) = Φ ( n + 1 ) ( ξ ) [ f ( x ) − p ( x ) ] − Φ ( x ) [ f ( n + 1 ) ( ξ ) − p ( n + 1 ) ( ξ ) ] = ( n + 1 ) ! [ f ( x ) − p ( x ) ] − Φ ( x ) f ( n + 1 ) ( ξ ) , \begin{align*}
0 = g_x^{(n+1)}(\xi) &= \Phi^{(n+1)}(\xi)[f(x)-p(x)] - \Phi(x)[f^{(n+1)}(\xi)-p^{(n+1)}(\xi)]\\
&= (n+1)!\,[f(x)-p(x)] - \Phi(x)f^{(n+1)}(\xi),
\end{align*} 0 = g x ( n + 1 ) ( ξ ) = Φ ( n + 1 ) ( ξ ) [ f ( x ) − p ( x )] − Φ ( x ) [ f ( n + 1 ) ( ξ ) − p ( n + 1 ) ( ξ )] = ( n + 1 )! [ f ( x ) − p ( x )] − Φ ( x ) f ( n + 1 ) ( ξ ) , which is a restatement of (9.1.8) .
Usually f ( n + 1 ) f^{(n+1)} f ( n + 1 ) and the function ξ ( x ) \xi(x) ξ ( x ) are unknown. The importance of the formula (9.1.8) is how it helps to express the error as a function of x x x , and its dependence on the nodes t 0 , … , t n t_0,\dots,t_n t 0 , … , t n . We will exploit this knowledge later.
Example 9.1.3 (Polynomial interpolation error)
Consider the problem of interpolating log ( x ) \log(x) log ( x ) at nodes 1 , 1.6 , 1.9 , 2.7 , 3 1, 1.6, 1.9, 2.7, 3 1 , 1.6 , 1.9 , 2.7 , 3 . Then n = 4 n=4 n = 4 and f ( 5 ) ( ξ ) = 4 ! / ξ 5 f^{(5)}(\xi) = 4!/\xi^5 f ( 5 ) ( ξ ) = 4 ! / ξ 5 . For ξ ∈ [ 1 , 3 ] \xi\in[1, 3] ξ ∈ [ 1 , 3 ] we can say that ∣ f ( 5 ) ( ξ ) ∣ ≤ 4 ! |f^{(5)}(\xi)| \le 4! ∣ f ( 5 ) ( ξ ) ∣ ≤ 4 ! . Hence
∣ f ( x ) − p ( x ) ∣ ≤ 1 5 ∣ Φ ( x ) ∣ . |f(x)-p(x)| \le \frac{1}{5} \left| \Phi(x) \right|. ∣ f ( x ) − p ( x ) ∣ ≤ 5 1 ∣ Φ ( x ) ∣ . Example 9.1.3 Consider the problem of interpolating log ( x ) \log(x) log ( x ) at these nodes:
t = [ 1, 1.6, 1.9, 2.7, 3 ]
n = length(t) - 1;
Here n = 4 n=4 n = 4 and f ( 5 ) ( ξ ) = 4 ! / ξ 5 f^{(5)}(\xi) = 4!/\xi^5 f ( 5 ) ( ξ ) = 4 ! / ξ 5 . For ξ ∈ [ 1 , 3 ] \xi\in[1,3] ξ ∈ [ 1 , 3 ] we can say that ∣ f ( 5 ) ( ξ ) ∣ ≤ 4 ! |f^{(5)}(\xi)| \le 4! ∣ f ( 5 ) ( ξ ) ∣ ≤ 4 ! . Hence
∣ f ( x ) − p ( x ) ∣ ≤ 1 5 ∣ Φ ( x ) ∣ . |f(x)-p(x)| \le \frac{1}{5} \left| \Phi(x) \right|. ∣ f ( x ) − p ( x ) ∣ ≤ 5 1 ∣ Φ ( x ) ∣ . Character Φ is typed as \Phi
Tab . (Note the capitalization.)
using Polynomials
Φ(x) = prod(x - tᵢ for tᵢ in t)
plot(x -> 0.2 * abs(Φ(x)), 1, 3, label=L"\frac{1}{5}|\Phi(t)|")
p = Polynomials.fit(t, log.(t))
plot!(t -> abs(log(t) - p(t)), 1, 3, label=L"|f(x)-p(x)|")
scatter!(t, zeros(size(t)), color=:black,
xaxis=(L"x"), title="Interpolation error and upper bound")
The error is zero at the nodes, by the definition of interpolation. The error bound, as well as the error itself, has one local maximum between each consecutive pair of nodes.
Example 9.1.3 t = [ 1, 1.6, 1.9, 2.7, 3 ];
n = length(t) - 1;
Phi = @(x) prod(x - t);
clf, fplot(@(x) Phi(x) / 5, [1, 3])
hold on, plot(t, 0*t, 'o')
xlabel('x'), ylabel('\Phi(x)')
title('Interpolation error function')
Warning: Function behaves unexpectedly on array inputs. To improve performance, properly vectorize your function to return an output with the same size and shape as the input arguments.
The error is zero at the nodes, by the definition of interpolation. The error bound, as well as the error itself, has one local maximum between each consecutive pair of nodes.
Example 9.1.3 from scipy.interpolate import BarycentricInterpolator as interp
t = array([1, 1.6, 1.9, 2.7, 3])
p = interp(t, log(t))
from scipy.interpolate import BarycentricInterpolator as interp
t = array([1, 1.6, 1.9, 2.7, 3])
p = interp(t, log(t))
x = linspace(1, 3, 500)
Phi = lambda x: prod([x - ti for ti in t])
plot(x, [Phi(xj) / 5 for xj in x], label="$\\frac{1}{5}|\\Phi(x)|$")
plot(x, abs(log(x) - p(x)), label="$|f(x)-p(x)|$")
plot(t, zeros(t.size), "ko", label="nodes")
xlabel("$x$"), ylabel("error")
title("Interpolation error and upper bound"), legend();
The error is zero at the nodes, by the definition of interpolation. The error bound, as well as the error itself, has one local maximum between each consecutive pair of nodes.
For equispaced nodes, Theorem 9.1.1 has an immediate consequence.
Suppose t i = i h t_i=i h t i = ih for constant step size h h h and all i = 0 , 1 , … , n i=0,1,\ldots,n i = 0 , 1 , … , n , and that f f f has n + 1 n+1 n + 1 continuous derivatives in ( t 0 , t n ) (t_0,t_n) ( t 0 , t n ) . If x ∈ [ t 0 , t n ] x\in[t_0,t_n] x ∈ [ t 0 , t n ] , then there exists ξ ( x ) ∈ ( t 0 , t n ) \xi(x)\in(t_0,t_n) ξ ( x ) ∈ ( t 0 , t n ) and C C C independent of x x x such that
∣ f ( x ) − p ( x ) ∣ ≤ C f ( n + 1 ) ( ξ ) h n + 1 . |f(x) - p(x)| \le C f^{(n+1)}(\xi) h^{n+1}. ∣ f ( x ) − p ( x ) ∣ ≤ C f ( n + 1 ) ( ξ ) h n + 1 . In particular, ∣ f ( x ) − p ( x ) ∣ = O ( h n + 1 ) |f(x)-p(x)|=O(h^{n+1}) ∣ f ( x ) − p ( x ) ∣ = O ( h n + 1 ) as h → 0 h\to 0 h → 0 .
If x ∈ [ t 0 , t n ] x\in[t_0,t_n] x ∈ [ t 0 , t n ] , then ∣ x − t i ∣ < n h |x-t_i|<nh ∣ x − t i ∣ < nh for all i i i , and (9.1.8) implies (9.1.12) . As h → 0 h\to 0 h → 0 , ξ → x \xi\to x ξ → x , and the continuity of f ( n + 1 ) f^{(n+1)} f ( n + 1 ) allows us to make the asymptotic conclusion.
This result is consistent with our observations in Convergence of finite differences : piecewise linear interpolation with node spacing h h h has accuracy O ( h 2 ) O(h^2) O ( h 2 ) , and the error of a finite-difference method for the first derivative based on n + 1 n+1 n + 1 nodes of spacing h h h is O ( h n ) O(h^n) O ( h n ) , remembering the division by h h h in a finite-difference formula.
As presented in (9.1.4) , the Lagrange formula is not a good choice for numerical computation, because it is unstable (see Exercise 7 ). In the next section we derive an algebraically equivalent formula that is both numerically stable and faster to apply.
9.1.3 Exercises ¶ ✍ Write out the Lagrange form of the interpolating polynomial of degree n n n for the given functions and nodes. Using a calculator, evaluate the polynomial at x = π / 4 x=\pi/4 x = π /4 and compute the error there.
(a) f ( x ) = sin ( x ) , n = 1 , t 0 = 0 , t 1 = π / 2 f(x) = \sin(x), \ n=1, \ t_0=0, t_1 = \pi/2 f ( x ) = sin ( x ) , n = 1 , t 0 = 0 , t 1 = π /2
(b) f ( x ) = sin ( x ) , n = 2 , t 0 = 0 , t 1 = π / 6 , t 2 = π / 2 f(x) = \sin(x), \ n=2, \ t_0=0, t_1 = \pi/6, t_2 = \pi/2 f ( x ) = sin ( x ) , n = 2 , t 0 = 0 , t 1 = π /6 , t 2 = π /2
(c) f ( x ) = cos ( x ) , n = 2 , t 0 = 0 , t 1 = π / 3 , t 2 = π / 2 f(x) = \cos(x), \ n=2, \ t_0=0, t_1 = \pi/3, t_2 = \pi/2 f ( x ) = cos ( x ) , n = 2 , t 0 = 0 , t 1 = π /3 , t 2 = π /2
(d) f ( x ) = tanh ( x ) , n = 2 , t 0 = 0 , t 1 = π / 3 , t 2 = π / 2 f(x) = \tanh(x), \ n=2, \ t_0=0, t_1 = \pi/3, t_2 = \pi/2 f ( x ) = tanh ( x ) , n = 2 , t 0 = 0 , t 1 = π /3 , t 2 = π /2
⌨ For each case, plot the requested Lagrange cardinal polynomial for the given set of nodes over the interval [ t 0 , t n ] [t_0,t_n] [ t 0 , t n ] . Superimpose dots or circles for the points represented by the cardinal conditions (9.1.1) .
(a) n = 2 , t 0 = − 1 , t 1 = − 0.2 , t 2 = 0 , ℓ 2 ( x ) n=2,\quad t_0=-1, \, t_1=-0.2,\, t_2=0, \quad \ell_2(x) n = 2 , t 0 = − 1 , t 1 = − 0.2 , t 2 = 0 , ℓ 2 ( x )
(b) n = 4 , t 0 = 0 , t 1 = 1 , t 2 = 1.5 , t 3 = 2.5 , t 4 = 3 , ℓ 3 ( x ) n=4,\quad t_0=0, \, t_1=1,\, t_2=1.5,\, t_3=2.5,\, t_4=3, \quad \ell_3(x) n = 4 , t 0 = 0 , t 1 = 1 , t 2 = 1.5 , t 3 = 2.5 , t 4 = 3 , ℓ 3 ( x )
(c) n = 20 , t i = i / n for i = 0 , … , n , ℓ 0 ( x ) n=20, \quad t_i=i/n \text{ for } i=0,\ldots,n, \quad \ell_0(x) n = 20 , t i = i / n for i = 0 , … , n , ℓ 0 ( x )
(d) n = 20 , t i = i / n for i = 0 , … , n , ℓ 10 ( x ) n=20, \quad t_i=i/n \text{ for } i=0,\ldots,n, \quad \ell_{10}(x) n = 20 , t i = i / n for i = 0 , … , n , ℓ 10 ( x )
(e) n = 40 , t i = i / n for i = 0 , … , n , ℓ 20 ( x ) n=40, \quad t_i=i/n \text{ for } i=0,\ldots,n, \quad \ell_{20}(x) n = 40 , t i = i / n for i = 0 , … , n , ℓ 20 ( x )
✍ Suppose p p p is the quadratic polynomial interpolating the points ( − 2 , 12 ) (-2,12) ( − 2 , 12 ) , ( 1 , 3 a ) (1,3a) ( 1 , 3 a ) , and ( 2 , 0 ) (2,0) ( 2 , 0 ) . Use (9.1.4) to compute p ′ ( 0 ) p'(0) p ′ ( 0 ) .
✍ Explain carefully why using (9.1.4) to compute p ( x ) p(x) p ( x ) at a single value of x x x takes O ( n 2 ) O(n^2) O ( n 2 ) floating-point operations.
✍ Explain why for any distribution of nodes and all x x x ,
1 = ∑ k = 0 n ℓ k ( x ) . 1 = \sum_{k=0}^n \ell_k(x). 1 = k = 0 ∑ n ℓ k ( x ) . (Hint: This problem does not require any hand computation or manipulation. What is being interpolated here?)
✍ Show that
ℓ k ( x ) = Φ ( x ) ( x − t k ) Φ ′ ( t k ) , \ell_k(x) = \frac{\Phi(x)}{(x-t_k)\Phi'(t_k)}, ℓ k ( x ) = ( x − t k ) Φ ′ ( t k ) Φ ( x ) , where Φ is the function defined in (9.1.7) .
✍ Consider the nodes t 0 = 0 t_0=0 t 0 = 0 , t 1 = 1 t_1=1 t 1 = 1 , t 2 = β t_2=\beta t 2 = β , where β > 1 \beta>1 β > 1 .
(a) Write out the Lagrange cardinal polynomials ℓ 0 \ell_0 ℓ 0 , ℓ 1 \ell_1 ℓ 1 , and ℓ 2 \ell_2 ℓ 2 .
(b) Set x = 1 / 2 x=1/2 x = 1/2 in the part (a) results, and suppose y 1 = y 2 y_1 = y_2 y 1 = y 2 . As β → 1 \beta\to 1 β → 1 from above, why should we expect subtractive cancellation?