Skip to article frontmatterSkip to article content

Stability of polynomial interpolation

With barycentric interpolation available in the form of Function 9.2.1, we can explore polynomial interpolation using a numerically stable algorithm. Any remaining sensitivity to error is due to the conditioning of the interpolation process itself.

9.3.1Runge phenomenon

The disappointing loss of convergence in Demo 9.3.1 is a sign of ill conditioning due to the use of equally spaced nodes. We will examine this effect using the error formula (9.1.8) as a guide:

f(x)p(x)=f(n+1)(ξ)(n+1)!Φ(x),Φ(x)=i=0n(xti).f(x) - p(x) = \frac{f^{(n+1)}(\xi)}{(n+1)!} \Phi(x), \qquad \Phi(x) = \prod_{i=0}^n (x-t_i).

While the dependence on ff is messy here, the error indicator Φ(x)\Phi(x) can be studied as a function of the nodes only.

Two observations from the result of Demo 9.3.2 are important. First, Φ|\Phi| decreases exponentially at each fixed location in the interval (note that the spacing between curves is constant for constant increments of nn). Second, Φ|\Phi| is larger at the ends of the interval than in the middle, by an exponentially growing factor. This gap is what can ruin the convergence of polynomial interpolation.

The observation of instability in Demo 9.3.3 is known as the Runge phenomenon. The Runge phenomenon is an instability manifested when the nodes of the interpolant are equally spaced and the degree of the polynomial increases. We reiterate that the phenomenon is rooted in the interpolation convergence theory and not a consequence of the algorithm chosen to implement polynomial interpolation.

Significantly, the convergence observed in Demo 9.3.3 is stable within a middle portion of the interval. By redistributing the interpolation nodes, we will next sacrifice a little of the convergence in the middle portion in order to improve it near the ends and rescue the process globally.

9.3.2Chebyshev nodes

The observations above hint that we might find success by having more nodes near the ends of the interval than in the middle. Though we will not give the details, it turns out that there is a precise asymptotic sense in which this must be done to make polynomial interpolation work over the entire interval. One especially important node family that gives stable convergence for polynomial interpolation is the Chebyshev points of the second kind (or Chebyshev extreme points) defined by

tk=cos(kπn),k=0,,n. t_k = - \cos\left(\frac{k \pi}{n}\right), \qquad k=0,\ldots,n.

These are the projections onto the xx-axis of nn equally spaced points on a unit circle. They are densely clustered near the ends of [1,1][-1,1], and this feature turns out to overcome the Runge phenomenon.

As a bonus, for Chebyshev nodes the barycentric weights are simple:

wk=(1)kdk,dk={1/2if k=0 or k=n,1otherwise. w_k = (-1)^k d_k, \qquad d_k = \begin{cases} 1/2 & \text{if $k=0$ or $k=n$},\\ 1 & \text{otherwise}. \end{cases}

9.3.3Spectral convergence

If we take nn\rightarrow \infty and use polynomial interpolation on Chebyshev nodes, the convergence rate is exponential in nn. The following is typical of the results that can be proved.

The condition “ff is analytic” means that the Taylor series of ff converges to f(x)f(x) in an open interval containing [1,1][-1,1].[1] A necessary condition of analyticity is that ff is infinitely differentiable.

In other contexts we refer to (9.3.4) as linear convergence, but here it is usual to say that the rate is exponential or that one has spectral convergence. It achieves constant reduction factors in the error by constant increments of nn. By contrast, algebraic convergence in the form O(np)O(n^{-p}) for some p>0p>0 requires multiplying nn by a constant factor in order to reduce error by a constant factor. Graphically, spectral error is a straight line on a log-linear scale, while algebraic convergence is a straight line on a log-log scale.

9.3.4Exercises

  1. ⌨ Revisit Demo 9.3.1 and determine an approximate value for the convergent phase of the constant KK mentioned in the comments there.

  2. ⌨ For each case, compute the polynomial interpolant using nn second-kind Chebyshev nodes in [1,1][-1,1] for n=4,8,12,,60n=4,8,12,\ldots,60. At each value of nn, compute the infinity-norm error (that is, maxp(x)f(x)\max |p(x)-f(x)| evaluated for at least 4000 values of xx). Using a log-linear scale, plot the error as a function of nn, then determine a good approximation to the constant KK in (9.3.4).

    (a) f(x)=1/(25x2+1)f(x) = 1/(25x^2+1)\qquad (b) f(x)=tanh(5x+2)f(x) = \tanh(5 x+2)

    (c) f(x)=cosh(sinx)f(x) = \cosh(\sin x)\qquad (d) f(x)=sin(coshx)f(x) = \sin(\cosh x)

  3. ⌨ Write a function chebinterp(f,n) that returns a function representing the polynomial interpolant of the input function f using n+1n+1 Chebyshev second kind nodes over [1,1][-1,1]. You should use (9.3.3) to compute the barycentric weights directly, rather than using the method in Function 9.2.1. Test your function by revisiting Demo 9.3.3 to use Chebyshev rather than equally spaced nodes.

  4. Theorem 9.3.1 assumes that the function being approximated has infinitely many derivatives over [1,1][-1,1]. But now consider the family of functions fm(x)=xmf_m(x)=|x|^m.

    (a) ✍ How many continuous derivatives over [1,1][-1,1] does fmf_m possess?

    (b) ⌨ Compute the polynomial interpolant using nn second-kind Chebyshev nodes in [1,1][-1,1] for n=10,20,30,,100n=10,20,30,\ldots,100. At each value of nn, compute the max-norm error (that is, maxp(x)fm(x)\max |p(x)-f_m(x)| evaluated for at least 41000 values of xx). Using a single log-log graph, plot the error as a function of nn for all six values m=1,3,5,7,9,11m=1,3,5,7,9,11.

    (c) ✍ Based on the results of parts (a) and (b), form a hypothesis about the asymptotic behavior of the error for fixed mm as nn\rightarrow \infty.

  5. The Chebyshev points can be used when the interval of interpolation is [a,b][a,b] rather than [1,1][-1,1] by means of the change of variable

    z=ψ(x)=a+(ba)(x+1)2. z = \psi(x) = a + (b-a)\frac{(x+1)}{2}.

    (a) ✍ Show that ψ(1)=a\psi(-1) = a, ψ(1)=b\psi(1) = b, and ψ is strictly increasing on [1,1][-1,1].

    (b) ✍ Invert the relation (9.3.5) to solve for xx in terms of ψ1(z)\psi^{-1}(z).

    (c) ✍ Let t0,,tnt_0,\ldots,t_n be standard second-kind Chebyshev points. Then a polynomial in xx can be used to interpolate the function values f(ψ(ti))f\bigl(\psi(t_i)\bigr). This in turn implies an interpolating function P~(z)=P(ψ1(z))\tilde{P}(z) =P\bigl(\psi^{-1}(z)\bigr). Show that P~\tilde{P} is a polynomial in zz.

    (d) ⌨ Implement the idea of part (c) to plot a polynomial interpolant of f(z)=cosh(sinz)f(z) =\cosh(\sin z) over [0,2π][0,2\pi] using n+1n+1 Chebyshev nodes with n=40n=40.

  6. The Chebyshev points can be used for interpolation of functions defined on the entire real line by using the change of variable

    z=ϕ(x)=2x1x2,z = \phi(x) = \frac{2x}{1-x^2},

    which maps the interval (1,1)(-1,1) in one-to-one fashion to the entire real line.

    (a) ✍ Find limx1ϕ(x)\displaystyle \lim_{x\to 1^-} \phi(x) and limx1+ϕ(x)\displaystyle \lim_{x\to -1^+} \phi(x).

    (b) ✍ Invert (9.3.6) to express x=ϕ1(z)x=\phi^{-1}(z). (Be sure to enforce 1x1-1\le x \le 1.)

    (c) ⌨ Let t0,,tnt_0,\ldots,t_n be standard second-kind Chebyshev points. These map to the zz variable as ζi=ϕ(ti)\zeta_i=\phi(t_i) for all ii. Suppose that f(z)f(z) is a given function whose domain is the entire real line. Then the function values yi=f(ζi)y_i=f(\zeta_i) can be associated with the Chebyshev nodes tit_i, leading to a polynomial interpolant p(x)p(x). This in turn implies an interpolating function on the real line, defined as

    q(z)=p(ϕ1(z))=p(x).q(z)=p\bigl(\phi^{-1}(z)\bigr) = p(x).

    Implement this idea to plot an interpolant of f(z)=(z22z+2)1f(z)=(z^2-2z+2)^{-1} using n=30n=30. Your plot should show q(z)q(z) evaluated at 1000 evenly spaced points in [6,6][-6,6], with markers at the nodal values (those lying within the [6,6][-6,6] window).

Footnotes
  1. Alternatively, analyticity means that the function is extensible to one that is differentiable in the complex plane.