Divided differences explained

In mathematics, divided differences is an algorithm, historically used for computing tables of logarithms and trigonometric functions. Charles Babbage's difference engine, an early mechanical calculator, was designed to use this algorithm in its operation.[1]

Divided differences is a recursive division process. Given a sequence of data points

(x0,y0),\ldots,(xn,yn)

, the method calculates the coefficients of the interpolation polynomial of these points in the Newton form.

Definition

Given n + 1 data points(x_0, y_0),\ldots,(x_, y_)where the

xk

are assumed to be pairwise distinct, the forward divided differences are defined as:\begin\mathopen[y_k] &:= y_k, && k \in \ \\\mathopen[y_k,\ldots,y_{k+j}] &:= \frac, && k\in\,\ j\in\.\end

To make the recursive process of computation clearer, the divided differences can be put in tabular form, where the columns correspond to the value of j above, and each entry in the table is computed from the difference of the entries to its immediate lower left and to its immediate upper left, divided by a difference of corresponding x-values:\beginx_0 & y_0 = [y_0] & & & \\ & & [y_0,y_1] & & \\x_1 & y_1 = [y_1] & & [y_0,y_1,y_2] & \\ & & [y_1,y_2] & & [y_0,y_1,y_2,y_3]\\x_2 & y_2 = [y_2] & & [y_1,y_2,y_3] & \\ & & [y_2,y_3] & & \\x_3 & y_3 = [y_3] & & & \\\end

Notation

Note that the divided difference

[yk,\ldots,yk+j]

depends on the values

xk,\ldots,xk+j

and

yk,\ldots,yk+j

, but the notation hides the dependency on the x-values. If the data points are given by a function f,(x_0, y_0), \ldots, (x_, y_n)=(x_0, f(x_0)), \ldots, (x_n, f(x_n))one sometimes writes the divided difference in the notationf[x_k,\ldots,x_{k+j}]\ \stackrel= \ [f(x_k),\ldots,f(x_{k+j})] = [y_k,\ldots,y_{k+j}].Other notations for the divided difference of the function ƒ on the nodes x0, ..., xn are:f[x_k,\ldots,x_{k+j}]=\mathopen[x_0,\ldots,x_n]f= \mathopen[x_0,\ldots,x_n;f]=D[x_0,\ldots,x_n]f.

Example

Divided differences for

k=0

and the first few values of

j

:\begin \mathopen[y_0] &= y_0 \\ \mathopen[y_0,y_1] &= \frac \\ \mathopen[y_0,y_1,y_2]&= \frac = \frac = \frac-\frac\\ \mathopen[y_0,y_1,y_2,y_3] &= \frac\end

Thus, the table corresponding to these terms upto two columns has the following form:\begin x_0 & y_ & & \\ & & & \\ x_1 & y_ & & \\ & & & \\ x_2 & y_ & & \vdots \\ & & \vdots & \\\vdots & & & \vdots \\ & & \vdots & \\ x_n & y_ & & \\\end

Properties

(f+g)[x_0,\dots,x_n] &= f[x_0,\dots,x_n] + g[x_0,\dots,x_n] \\(\lambda\cdot f)[x_0,\dots,x_n] &= \lambda\cdot f[x_0,\dots,x_n]\end

\sigma:\{0,...,n\}\to\{0,...,n\}

is a permutation then f[x_0, \dots, x_n] = f[x_{\sigma(0)}, \dots, x_{\sigma(n)}]

P

is a polynomial function of degree

\leqn

, and

p[x0,...,xn]

is the divided difference, then P_(x) = p[x_0] + p[x_0,x_1](x-x_0) + p[x_0,x_1,x_2](x-x_0)(x-x_1) + \cdots + p[x_0,\ldots,x_n] (x-x_0)(x-x_1)\cdots(x-x_)

p

is a polynomial function of degree

<n

, then p[x_0, \dots, x_n] = 0.

if

f

is n times differentiable, then f[x_0,\dots,x_n] = \frac for a number

\xi

in the open interval determined by the smallest and largest of the

xk

's.

Matrix form

The divided difference scheme can be put into an upper triangular matrix:T_f(x_0,\dots,x_n)=\beginf[x_0] & f[x_0,x_1] & f[x_0,x_1,x_2] & \ldots & f[x_0,\dots,x_n] \\0 & f[x_1] & f[x_1,x_2] & \ldots & f[x_1,\dots,x_n] \\0 & 0 & f[x_2] & \ldots & f[x_2,\dots,x_n] \\\vdots & \vdots & & \ddots & \vdots \\0 & 0 & 0 & \ldots & f[x_n]\end.

Then it holds

Tf+g(x)=Tf(x)+Tg(x)

Tλ(x)=λTf(x)

if

λ

is a scalar

Tf(x)=Tf(x)Tg(x)

This follows from the Leibniz rule. It means that multiplication of such matrices is commutative. Summarised, the matrices of divided difference schemes with respect to the same set of nodes x form a commutative ring.

Tf(x)

is a triangular matrix, its eigenvalues are obviously

f(x0),...,f(xn)

.

\delta\xi

be a Kronecker delta-like function, that is \delta_\xi(t) = \begin1 &: t=\xi, \\0 &: \mbox.\end Obviously

f\delta\xi=f(\xi)\delta\xi

, thus

\delta\xi

is an eigenfunction of the pointwise function multiplication. That is
T
\delta
xi

(x)

is somehow an "eigenmatrix" of

Tf(x)

:

Tf(x)

T
\delta
xi

(x)=f(xi)

T
\delta
xi

(x)

. However, all columns of
T
\delta
xi

(x)

are multiples of each other, the matrix rank of
T
\delta
xi

(x)

is 1. So you can compose the matrix of all eigenvectors of

Tf(x)

from the

i

-th column of each
T
\delta
xi

(x)

. Denote the matrix of eigenvectors with

U(x)

. Example U(x_0,x_1,x_2,x_3) = \begin1 & \frac & \frac & \frac \\0 & 1 & \frac & \frac \\0 & 0 & 1 & \frac \\0 & 0 & 0 & 1\end The diagonalization of

Tf(x)

can be written as U(x) \cdot \operatorname(f(x_0),\dots,f(x_n)) = T_f(x) \cdot U(x) .

Polynomials and power series

The matrix J =\beginx_0 & 1 & 0 & 0 & \cdots & 0 \\0 & x_1 & 1 & 0 & \cdots & 0 \\0 & 0 & x_2 & 1 & & 0 \\\vdots & \vdots & & \ddots & \ddots & \\0 & 0 & 0 & 0 & \; \ddots & 1\\0 & 0 & 0 & 0 & & x_n\endcontains the divided difference scheme for the identity function with respect to the nodes

x0,...,xn

, thus

Jm

contains the divided differences for the power function with exponent

m

.Consequently, you can obtain the divided differences for a polynomial function

p

by applying

p

to the matrix

J

: Ifp(\xi) = a_0 + a_1 \cdot \xi + \dots + a_m \cdot \xi^mandp(J) = a_0 + a_1\cdot J + \dots + a_m\cdot J^mthenT_p(x) = p(J).This is known as Opitz' formula.[2] [3]

Now consider increasing the degree of

p

to infinity, i.e. turn the Taylor polynomial into a Taylor series.Let

f

be a function which corresponds to a power series.You can compute the divided difference scheme for

f

by applying the corresponding matrix series to

J

:Iff(\xi) = \sum_^\infty a_k \xi^kandf(J)=\sum_^\infty a_k J^kthenT_f(x)=f(J).

Alternative characterizations

Expanded form

\beginf[x_0] &= f(x_0) \\f[x_0,x_1] &= \frac + \frac \\f[x_0,x_1,x_2] &= \frac + \frac + \frac \\f[x_0,x_1,x_2,x_3] &= \frac + \frac +\\&\quad\quad \frac + \frac \\f[x_0,\dots,x_n] &=\sum_^ \frac\end

\omega(\xi)=(\xi-x0)(\xi-xn)

this can be written asf[x_0,\dots,x_n] = \sum_^ \frac.

Peano form

If

x0<x1<<xn

and

n\geq1

, the divided differences can be expressed as[4] f[x_0,\ldots,x_n] = \frac \int_^ f^(t)\;B_(t) \, dtwhere

f(n)

is the

n

-th derivative of the function

f

and

Bn-1

is a certain B-spline of degree

n-1

for the data points

x0,...,xn

, given by the formulaB_(t) = \sum_^n \frac

This is a consequence of the Peano kernel theorem; it is called the Peano form of the divided differences and

Bn-1

is the Peano kernel for the divided differences, all named after Giuseppe Peano.

Forward and backward differences

When the data points are equidistantly distributed we get the special case called forward differences. They are easier to calculate than the more general divided differences.

Given n+1 data points(x_0, y_0), \ldots, (x_n, y_n)withx_ = x_0 + k h,\ \text \ k=0,\ldots,n \text h>0the forward differences are defined as\begin\Delta^ y_k &:= y_k,\qquad k=0,\ldots,n \\\Delta^y_k &:= \Delta^y_ - \Delta^y_k,\qquad k=0,\ldots,n-j,\ j=1,\dots,n.\endwhereas the backward differences are defined as:\begin\nabla^ y_k &:= y_k,\qquad k=0,\ldots,n \\\nabla^y_k &:= \nabla^y_ - \nabla^y_,\qquad k=0,\ldots,n-j,\ j=1,\dots,n.\endThus the forward difference table is written as:\beginy_0 & & & \\ & \Delta y_0 & & \\y_1 & & \Delta^2 y_0 & \\ & \Delta y_1 & & \Delta^3 y_0\\y_2 & & \Delta^2 y_1 & \\ & \Delta y_2 & & \\y_3 & & & \\\endwhereas the backwards difference table is written as:\beginy_0 & & & \\ & \nabla y_1 & & \\y_1 & & \nabla^2 y_2 & \\ & \nabla y_2 & & \nabla^3 y_3\\y_2 & & \nabla^2 y_3 & \\ & \nabla y_3 & & \\y_3 & & & \\\end

The relationship between divided differences and forward differences is[5] [y_j, y_{j+1}, \ldots, y_{j+k}] = \frac\Delta^y_j, whereas for backward differences:[{y}_{j}, y_{j-1},\ldots,{y}_{j-k}] = \frac\nabla^y_j.

See also

References

External links

Notes and References

  1. Book: Isaacson . Walter . The Innovators . 2014 . Simon & Schuster . 978-1-4767-0869-0 . 20 .
  2. [Carl de Boor|de Boor, Carl]
  3. Opitz, G. Steigungsmatrizen, Z. Angew. Math. Mech. (1964), 44, T52–T54
  4. Book: Skof, Fulvia . Giuseppe Peano between Mathematics and Logic: Proceeding of the International Conference in honour of Giuseppe Peano on the 150th anniversary of his birth and the centennial of the Formulario Mathematico Torino (Italy) October 2-3, 2008 . 2011-04-30 . Springer Science & Business Media . 978-88-470-1836-5 . 40 . en.
  5. Book: Burden. Richard L.. Faires. J. Douglas . Numerical Analysis . limited . 2011. 129. Cengage Learning . 9780538733519. 9th.