Recurrence relation

(Redirected from Difference operator)

In mathematics, a recurrence relation is an equation that expresses the nth term of a sequence as a function of the k preceding terms, for some fixed k (independent from n), which is called the order of the relation. Once k initial terms of a sequence are given, the recurrence relation allows computing recursively all terms of the sequence.

Most general results on recurrence relations are about linear recurrences, which are recurrence relations such that the nth term is linear with respect to its preceding terms. Among them, linear recurrences with constant coefficients, and linear recurrences with polynomial coefficients are especially important. In the first case, this is because one can express the general term of the sequence as a closed-form expression of the index of the term. In the second case, this is because many common elementary and special functions have a Taylor series whose coefficients satisfy such a recurrence relation (see holonomic function).

The concept can be extended to multidimensional arrays, that is, indexed families that are indexed by tuples of natural numbers.

Definition

A recurrence relation is an equation that expresses each element of a sequence as a function of the preceding ones. More precisely, in the case where only the immediately preceding element is involved, a recurrence relation has the form

$u_{n}=\varphi (n,u_{n-1})\quad {\text{for}}\quad n>0,$

where

$\varphi :\mathbb {N} \times X\to X$

is a function, where X is a set to which the elements of a sequence must belong. For any $u_{0}\in X$ , this defines a unique sequence with $u_{0}$  as its first element, called the initial value.

It is easy to modify the definition for getting sequences starting from the term of index 1 or higher.

This defines recurrence relation of first order. A recurrence relation of order k has the form

$u_{n}=\varphi (n,u_{n-1},u_{n-2},\ldots ,u_{n-k})\quad {\text{for}}\quad n\geq k,$

where $\varphi :\mathbb {N} \times X^{k}\to X$  is a function that involves k consecutive elements of the sequence. In this case, k initial values are needed for defining a sequence.

Examples

Factorial

The factorial is defined by the recurrence relation

$n!=n(n-1)!\quad {\text{for}}\quad n>0,$

and the initial condition

$0!=1.$

Logistic map

An example of a recurrence relation is the logistic map:

$x_{n+1}=rx_{n}(1-x_{n}),$

with a given constant $r$ ; given the initial term $x_{0}$  each subsequent term is determined by this relation.

Solving a recurrence relation means obtaining a closed-form solution: a non-recursive function of $n$ .

Fibonacci numbers

The recurrence of order two satisfied by the Fibonacci numbers is the canonical example of a homogeneous linear recurrence relation with constant coefficients (see below). The Fibonacci sequence is defined using the recurrence

$F_{n}=F_{n-1}+F_{n-2}$
$F_{0}=0$
$F_{1}=1.$

Explicitly, the recurrence yields the equations

$F_{2}=F_{1}+F_{0}$
$F_{3}=F_{2}+F_{1}$
$F_{4}=F_{3}+F_{2}$

etc.

We obtain the sequence of Fibonacci numbers, which begins

0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, ...

The recurrence can be solved by methods described below yielding Binet's formula, which involves powers of the two roots of the characteristic polynomial $t^{2}=t+1$ ; the generating function of the sequence is the rational function

${\frac {t}{1-t-t^{2}}}.$

Binomial coefficients

A simple example of a multidimensional recurrence relation is given by the binomial coefficients ${\tbinom {n}{k}}$ , which count the number of ways of selecting $k$  elements out of a set of $n$  elements. They can be computed by the recurrence relation

${\binom {n}{k}}={\binom {n-1}{k-1}}+{\binom {n-1}{k}},$

with the base cases ${\tbinom {n}{0}}={\tbinom {n}{n}}=1$ . Using this formula to compute the values of all binomial coefficients generates an infinite array called Pascal's triangle. The same values can also be computed directly by a different formula that is not a recurrence, but that requires multiplication and not just addition to compute: ${\binom {n}{k}}={\frac {n!}{k!(n-k)!}}.$

Difference operator and difference equations

The difference operator is an operator that maps sequences to sequences, and, more generally, functions to functions. It is commonly denoted $\Delta ,$  and is defined, in functional notation, as

$(\Delta f)(x)=f(x+1)-f(x).$

It is thus a special case of finite difference.

When using the index notation for sequences, the definition becomes

$(\Delta a)_{n}=a_{n+1}-a_{n}.$

The parentheses around $\Delta f$  and $\Delta a$  are generally omitted, and $\Delta a_{n}$  must be understood as the term of index n in the sequence $\Delta a,$  and not $\Delta$  applied to the element $a_{n}.$

Given sequence $a=(a_{n})_{n\in \mathbb {N} },$  the first difference of a is $\Delta a.$

The second difference is $\Delta ^{2}a=(\Delta \circ \Delta )a=\Delta (\Delta a).$  A simple computation shows that

$\Delta ^{2}a_{n}=a_{n+2}-2a_{n+1}+a_{n}.$

More generally: the kth difference is defined recursively as $\Delta ^{k}=\Delta \circ \Delta ^{n-1},$  and one has

$\Delta ^{k}a_{n}=\sum _{t=0}^{k}(-1)^{t}{\binom {k}{t}}a_{n+k-t}.$

This relation can be inverted, giving

$a_{n+k}=a_{n}+{k \choose 1}\Delta a_{n}+\cdots +{k \choose k}\Delta ^{k}(a_{n}).$

A difference equation of order k is an equation that involves the k first differences of a sequence or a function, in the same way as a differential equation of order k relates the k first derivatives of a function.

The two above relations allow transforming a recurrence relation of order k into a difference equation of order k, and, conversely, a difference equation of order k into recurrence relation of order k. Each transformation is the inverse of the other, and the sequences that are solution of the difference equation are exactly those that satisfies the recurrence relation.

For example, the difference equation

$3\Delta ^{2}a_{n}+2\Delta a_{n}+7a_{n}=0$

is equivalent to the recurrence relation

$3a_{n+2}=4a_{n+1}-8a_{n},$

in the sense that the two equations are satisfied by the same sequences.

As it is equivalent for a sequence to satisfy a recurrence relation or to be the solution of a recurrence relation, the two terms "recurrence relation" and "difference equation" are sometimes used interchangeably. See Rational difference equation and Matrix difference equation for example of uses of "difference equation" instead of "recurrence relation"

Difference equations resemble to differential equations, and this resemblance is often used for mimic methods for solving differentiable equations for solving difference equations, and therefore recurrence relations.

Summation equations relate to difference equations as integral equations relate to differential equations. See time scale calculus for a unification of the theory of difference equations with that of differential equations.

From sequences to grids

Single-variable or one-dimensional recurrence relations are about sequences (i.e. functions defined on one-dimensional grids). Multi-variable or n-dimensional recurrence relations are about $n$ -dimensional grids. Functions defined on $n$ -grids can also be studied with partial difference equations.

Solving

Solving first-order non-homogeneous recurrence relations with variable coefficients

Moreover, for the general first-order non-homogeneous linear recurrence relation with variable coefficients:

$a_{n+1}=f_{n}a_{n}+g_{n},\qquad f_{n}\neq 0,$

there is also a nice method to solve it:

$a_{n+1}-f_{n}a_{n}=g_{n}$
${\frac {a_{n+1}}{\prod _{k=0}^{n}f_{k}}}-{\frac {f_{n}a_{n}}{\prod _{k=0}^{n}f_{k}}}={\frac {g_{n}}{\prod _{k=0}^{n}f_{k}}}$
${\frac {a_{n+1}}{\prod _{k=0}^{n}f_{k}}}-{\frac {a_{n}}{\prod _{k=0}^{n-1}f_{k}}}={\frac {g_{n}}{\prod _{k=0}^{n}f_{k}}}$

Let

$A_{n}={\frac {a_{n}}{\prod _{k=0}^{n-1}f_{k}}},$

Then

$A_{n+1}-A_{n}={\frac {g_{n}}{\prod _{k=0}^{n}f_{k}}}$
$\sum _{m=0}^{n-1}(A_{m+1}-A_{m})=A_{n}-A_{0}=\sum _{m=0}^{n-1}{\frac {g_{m}}{\prod _{k=0}^{m}f_{k}}}$
${\frac {a_{n}}{\prod _{k=0}^{n-1}f_{k}}}=A_{0}+\sum _{m=0}^{n-1}{\frac {g_{m}}{\prod _{k=0}^{m}f_{k}}}$
$a_{n}=\left(\prod _{k=0}^{n-1}f_{k}\right)\left(A_{0}+\sum _{m=0}^{n-1}{\frac {g_{m}}{\prod _{k=0}^{m}f_{k}}}\right)$

If we apply the formula to $a_{n+1}=(1+hf_{nh})a_{n}+hg_{nh}$  and take the limit $h\to 0$ , we get the formula for first order linear differential equations with variable coefficients; the sum becomes an integral, and the product becomes the exponential function of an integral.

Solving general homogeneous linear recurrence relations

Many homogeneous linear recurrence relations may be solved by means of the generalized hypergeometric series. Special cases of these lead to recurrence relations for the orthogonal polynomials, and many special functions. For example, the solution to

$J_{n+1}={\frac {2n}{z}}J_{n}-J_{n-1}$

is given by

$J_{n}=J_{n}(z),$

the Bessel function, while

$(b-n)M_{n-1}+(2n-b-z)M_{n}-nM_{n+1}=0$

is solved by

$M_{n}=M(n,b;z)$

the confluent hypergeometric series. Sequences which are the solutions of linear difference equations with polynomial coefficients are called P-recursive. For these specific recurrence equations algorithms are known which find polynomial, rational or hypergeometric solutions.

Solving first-order rational difference equations

A first order rational difference equation has the form $w_{t+1}={\tfrac {aw_{t}+b}{cw_{t}+d}}$ . Such an equation can be solved by writing $w_{t}$  as a nonlinear transformation of another variable $x_{t}$  which itself evolves linearly. Then standard methods can be used to solve the linear difference equation in $x_{t}$ .

Stability

Stability of linear higher-order recurrences

The linear recurrence of order $d$ ,

$a_{n}=c_{1}a_{n-1}+c_{2}a_{n-2}+\cdots +c_{d}a_{n-d},$

has the characteristic equation

$\lambda ^{d}-c_{1}\lambda ^{d-1}-c_{2}\lambda ^{d-2}-\cdots -c_{d}\lambda ^{0}=0.$

The recurrence is stable, meaning that the iterates converge asymptotically to a fixed value, if and only if the eigenvalues (i.e., the roots of the characteristic equation), whether real or complex, are all less than unity in absolute value.

Stability of linear first-order matrix recurrences

In the first-order matrix difference equation

$[x_{t}-x^{*}]=A[x_{t-1}-x^{*}]$

with state vector $x$  and transition matrix $A$ , $x$  converges asymptotically to the steady state vector $x^{*}$  if and only if all eigenvalues of the transition matrix $A$  (whether real or complex) have an absolute value which is less than 1.

Stability of nonlinear first-order recurrences

Consider the nonlinear first-order recurrence

$x_{n}=f(x_{n-1}).$

This recurrence is locally stable, meaning that it converges to a fixed point $x^{*}$  from points sufficiently close to $x^{*}$ , if the slope of $f$  in the neighborhood of $x^{*}$  is smaller than unity in absolute value: that is,

$|f'(x^{*})|<1.$

A nonlinear recurrence could have multiple fixed points, in which case some fixed points may be locally stable and others locally unstable; for continuous f two adjacent fixed points cannot both be locally stable.

A nonlinear recurrence relation could also have a cycle of period $k$  for $k>1$ . Such a cycle is stable, meaning that it attracts a set of initial conditions of positive measure, if the composite function

$g(x):=f\circ f\circ \cdots \circ f(x)$

with $f$  appearing $k$  times is locally stable according to the same criterion:

$|g'(x^{*})|<1,$

where $x^{*}$  is any point on the cycle.

In a chaotic recurrence relation, the variable $x$  stays in a bounded region but never converges to a fixed point or an attracting cycle; any fixed points or cycles of the equation are unstable. See also logistic map, dyadic transformation, and tent map.

Relationship to differential equations

When solving an ordinary differential equation numerically, one typically encounters a recurrence relation. For example, when solving the initial value problem

$y'(t)=f(t,y(t)),\ \ y(t_{0})=y_{0},$

with Euler's method and a step size $h$ , one calculates the values

$y_{0}=y(t_{0}),\ \ y_{1}=y(t_{0}+h),\ \ y_{2}=y(t_{0}+2h),\ \dots$

by the recurrence

$\,y_{n+1}=y_{n}+hf(t_{n},y_{n}),t_{n}=t_{0}+nh$

Systems of linear first order differential equations can be discretized exactly analytically using the methods shown in the discretization article.

Applications

Biology

Some of the best-known difference equations have their origins in the attempt to model population dynamics. For example, the Fibonacci numbers were once used as a model for the growth of a rabbit population.

The logistic map is used either directly to model population growth, or as a starting point for more detailed models of population dynamics. In this context, coupled difference equations are often used to model the interaction of two or more populations. For example, the Nicholson–Bailey model for a host-parasite interaction is given by

$N_{t+1}=\lambda N_{t}e^{-aP_{t}}$
$P_{t+1}=N_{t}(1-e^{-aP_{t}}),$

with $N_{t}$  representing the hosts, and $P_{t}$  the parasites, at time $t$ .

Integrodifference equations are a form of recurrence relation important to spatial ecology. These and other difference equations are particularly suited to modeling univoltine populations.

Computer science

Recurrence relations are also of fundamental importance in analysis of algorithms. If an algorithm is designed so that it will break a problem into smaller subproblems (divide and conquer), its running time is described by a recurrence relation.

A simple example is the time an algorithm takes to find an element in an ordered vector with $n$  elements, in the worst case.

A naive algorithm will search from left to right, one element at a time. The worst possible scenario is when the required element is the last, so the number of comparisons is $n$ .

A better algorithm is called binary search. However, it requires a sorted vector. It will first check if the element is at the middle of the vector. If not, then it will check if the middle element is greater or lesser than the sought element. At this point, half of the vector can be discarded, and the algorithm can be run again on the other half. The number of comparisons will be given by

$c_{1}=1$
$c_{n}=1+c_{n/2}$

the time complexity of which will be $O(\log _{2}(n))$ .

Digital signal processing

In digital signal processing, recurrence relations can model feedback in a system, where outputs at one time become inputs for future time. They thus arise in infinite impulse response (IIR) digital filters.

For example, the equation for a "feedforward" IIR comb filter of delay $T$  is:

$y_{t}=(1-\alpha )x_{t}+\alpha y_{t-T},$

where $x_{t}$  is the input at time $t$ , $y_{t}$  is the output at time $t$ , and $\alpha$  controls how much of the delayed signal is fed back into the output. From this we can see that

$y_{t}=(1-\alpha )x_{t}+\alpha ((1-\alpha )x_{t-T}+\alpha y_{t-2T})$
$y_{t}=(1-\alpha )x_{t}+(\alpha -\alpha ^{2})x_{t-T}+\alpha ^{2}y_{t-2T}$

etc.

Economics

Recurrence relations, especially linear recurrence relations, are used extensively in both theoretical and empirical economics. In particular, in macroeconomics one might develop a model of various broad sectors of the economy (the financial sector, the goods sector, the labor market, etc.) in which some agents' actions depend on lagged variables. The model would then be solved for current values of key variables (interest rate, real GDP, etc.) in terms of past and current values of other variables.