# Generating function

(Redirected from Ordinary generating function)
This article is about generating functions in mathematics. For generating functions in classical mechanics, see Generating function (physics). For signalling molecule, see Epidermal growth factor. For Generator in computer programming, see Generator (computer programming).

In mathematics, generating function is used to describe an infinite sequence of numbers (an) by treating them as the coefficients of a series expansion. The sum of this infinite series is the generating function. Unlike an ordinary series, this formal series is allowed to diverge, meaning that the generating function is not always a true function and the "variable" is actually an indeterminate. Generating functions were first introduced by Abraham de Moivre in 1730, in order to solve the general linear recurrence problem.[1] One can generalize to formal series in more than one indeterminate, to encode information about arrays of numbers indexed by several natural numbers.

There are various types of generating functions, including ordinary generating functions, exponential generating functions, Lambert series, Bell series, and Dirichlet series; definitions and examples are given below. Every sequence in principle has a generating function of each type (except that Lambert and Dirichlet series require indices to start at 1 rather than 0), but the ease with which they can be handled may differ considerably. The particular generating function, if any, that is most useful in a given context will depend upon the nature of the sequence and the details of the problem being addressed.

Generating functions are often expressed in closed form (rather than as a series), by some expression involving operations defined for formal series. These expressions in terms of the indeterminate x may involve arithmetic operations, differentiation with respect to x and composition with (i.e., substitution into) other generating functions; since these operations are also defined for functions, the result looks like a function of x. Indeed, the closed form expression can often be interpreted as a function that can be evaluated at (sufficiently small) concrete values of x, and which has the formal series as its series expansion; this explains the designation "generating functions". However such interpretation is not required to be possible, because formal series are not required to give a convergent series when a nonzero numeric value is substituted for x. Also, not all expressions that are meaningful as functions of x are meaningful as expressions designating formal series; for example, negative and fractional powers of x are examples of functions that do not have a corresponding formal power series.

Generating functions are not functions in the formal sense of a mapping from a domain to a codomain. Generating functions are sometimes called generating series,[2] in that a series of terms can be said to be the generator of its sequence of term coefficients.

## Definitions

A generating function is a device somewhat similar to a bag. Instead of carrying many little objects detachedly, which could be embarrassing, we put them all in a bag, and then we have only one object to carry, the bag.
George Polya, Mathematics and plausible reasoning (1954)
A generating function is a clothesline on which we hang up a sequence of numbers for display.
Herbert Wilf, Generatingfunctionology (1994)

### Ordinary generating function

The ordinary generating function of a sequence an is

${\displaystyle G(a_{n};x)=\sum _{n=0}^{\infty }a_{n}x^{n}.}$

When the term generating function is used without qualification, it is usually taken to mean an ordinary generating function.

If an is the probability mass function of a discrete random variable, then its ordinary generating function is called a probability-generating function.

The ordinary generating function can be generalized to arrays with multiple indices. For example, the ordinary generating function of a two-dimensional array am, n (where n and m are natural numbers) is

${\displaystyle G(a_{m,n};x,y)=\sum _{m,n=0}^{\infty }a_{m,n}x^{m}y^{n}.}$

### Exponential generating function

The exponential generating function of a sequence an is

${\displaystyle \operatorname {EG} (a_{n};x)=\sum _{n=0}^{\infty }a_{n}{\frac {x^{n}}{n!}}.}$

Exponential generating functions are generally more convenient than ordinary generating functions for combinatorial enumeration problems that involve labelled objects.[3]

### Poisson generating function

The Poisson generating function of a sequence an is

${\displaystyle \operatorname {PG} (a_{n};x)=\sum _{n=0}^{\infty }a_{n}e^{-x}{\frac {x^{n}}{n!}}=e^{-x}\,\operatorname {EG} (a_{n};x).}$

### Lambert series

The Lambert series of a sequence an is

${\displaystyle \operatorname {LG} (a_{n};x)=\sum _{n=1}^{\infty }a_{n}{\frac {x^{n}}{1-x^{n}}}.}$

Note that in a Lambert series the index n starts at 1, not at 0, as the first term would otherwise be undefined.

### Bell series

The Bell series of a sequence an is an expression in terms of both an indeterminate x and a prime p and is given by[4]

${\displaystyle \operatorname {BG} _{p}(a_{n};x)=\sum _{n=0}^{\infty }a_{p^{n}}x^{n}.}$

### Dirichlet series generating functions

Formal Dirichlet series are often classified as generating functions, although they are not strictly formal power series. The Dirichlet series generating function of a sequence an is[5]

${\displaystyle \operatorname {DG} (a_{n};s)=\sum _{n=1}^{\infty }{\frac {a_{n}}{n^{s}}}.}$

The Dirichlet series generating function is especially useful when an is a multiplicative function, in which case it has an Euler product expression[6] in terms of the function's Bell series

${\displaystyle \operatorname {DG} (a_{n};s)=\prod _{p}\operatorname {BG} _{p}(a_{n};p^{-s})\,.}$

If an is a Dirichlet character then its Dirichlet series generating function is called a Dirichlet L-series.

### Polynomial sequence generating functions

The idea of generating functions can be extended to sequences of other objects. Thus, for example, polynomial sequences of binomial type are generated by

${\displaystyle e^{xf(t)}=\sum _{n=0}^{\infty }{\frac {p_{n}(x)}{n!}}t^{n}}$

where pn(x) is a sequence of polynomials and f(t) is a function of a certain form. Sheffer sequences are generated in a similar way. See the main article generalized Appell polynomials for more information.

## Ordinary generating functions

Polynomials are a special case of ordinary generating functions, corresponding to finite sequences, or equivalently sequences that vanish after a certain point. These are important in that many finite sequences can usefully be interpreted as generating functions, such as the Poincaré polynomial and others.

A key generating function is that of the constant sequence 1, 1, 1, 1, 1, 1, 1, 1, 1, ..., whose ordinary generating function is

${\displaystyle \sum _{n=0}^{\infty }x^{n}={\frac {1}{1-x}}.}$

The left-hand side is the Maclaurin series expansion of the right-hand side. Alternatively, the right-hand side expression can be justified by multiplying the power series on the left by 1 − x, and checking that the result is the constant power series 1, in other words that all coefficients except the one of x0 vanish. Moreover, there can be no other power series with this property. The left-hand side therefore designates the multiplicative inverse of 1 − x in the ring of power series.

Expressions for the ordinary generating function of other sequences are easily derived from this one. For instance, the substitution x → ax gives the generating function for the geometric sequence 1, a, a2, a3, ... for any constant a:

${\displaystyle \sum _{n=0}^{\infty }(ax)^{n}={\frac {1}{1-ax}}.}$

(The equality also follows directly from the fact that the left-hand side is the Maclaurin series expansion of the right-hand side.) In particular,

${\displaystyle \sum _{n=0}^{\infty }(-1)^{n}x^{n}={\frac {1}{1+x}}.}$

One can also introduce regular "gaps" in the sequence by replacing x by some power of x, so for instance for the sequence 1, 0, 1, 0, 1, 0, 1, 0, .... one gets the generating function

${\displaystyle \sum _{n=0}^{\infty }x^{2n}={\frac {1}{1-x^{2}}}.}$

By squaring the initial generating function, or by finding the derivative of both sides with respect to x and making a change of running variable n → n-1, one sees that the coefficients form the sequence 1, 2, 3, 4, 5, ..., so one has

${\displaystyle \sum _{n=0}^{\infty }(n+1)x^{n}={\frac {1}{(1-x)^{2}}},}$

and the third power has as coefficients the triangular numbers 1, 3, 6, 10, 15, 21, ... whose term n is the binomial coefficient ${\displaystyle {\tbinom {n+2}{2}}}$, so that

${\displaystyle \sum _{n=0}^{\infty }{\binom {n+2}{2}}x^{n}={\frac {1}{(1-x)^{3}}}.}$

More generally, for any non-negative integer k and non-zero real value a, it is true that

${\displaystyle \sum _{n=0}^{\infty }a^{n}{\binom {n+k}{k}}x^{n}={\frac {1}{(1-ax)^{k+1}}}\,.}$

Note that, since

${\displaystyle 2{\binom {n+2}{2}}-3{\binom {n+1}{1}}+{\binom {n}{0}}=2{\frac {(n+1)(n+2)}{2}}-3(n+1)+1=n^{2},}$

one can find the ordinary generating function for the sequence 0, 1, 4, 9, 16, ... of square numbers by linear combination of binomial-coefficient generating sequences;

${\displaystyle G(n^{2};x)=\sum _{n=0}^{\infty }n^{2}x^{n}={\frac {2}{(1-x)^{3}}}-{\frac {3}{(1-x)^{2}}}+{\frac {1}{1-x}}={\frac {x(x+1)}{(1-x)^{3}}}.}$

### Rational functions

The ordinary generating function of a sequence can be expressed as a rational function (the ratio of two polynomials) if and only if the sequence is a linear recursive sequence with constant coefficients; this generalizes the examples above. Going in the reverse direction, every sequence generated by a fraction of polynomials satisfies a linear recurrence with constant coefficients; these coefficients are identical to the coefficients of the fraction denominator polynomial (so they can be directly read off).

### Multiplication yields convolution

Main article: Cauchy product

Multiplication of ordinary generating functions yields a discrete convolution (the Cauchy product) of the sequences. For example, the sequence of cumulative sums

${\displaystyle (a_{0},a_{0}+a_{1},a_{0}+a_{1}+a_{2},\cdots )}$

of a sequence with ordinary generating function G(anx) has the generating function

${\displaystyle G(a_{n};x)\cdot {\frac {1}{1-x}}}$

because 1/(1-x) is the ordinary generating function for the sequence (1, 1, ...).

### Relation to discrete-time Fourier transform

When the series converges absolutely,

${\displaystyle G\left(a_{n};e^{-i\omega }\right)=\sum _{n=0}^{\infty }a_{n}e^{-i\omega n}}$

is the discrete-time Fourier transform of the sequence a0a1, ....

### Asymptotic growth of a sequence

In calculus, often the growth rate of the coefficients of a power series can be used to deduce a radius of convergence for the power series. The reverse can also hold; often the radius of convergence for a generating function can be used to deduce the asymptotic growth of the underlying sequence.

For instance, if an ordinary generating function G(anx) that has a finite radius of convergence of r can be written as

${\displaystyle G(a_{n};x)={\frac {A(x)+B(x)\left(1-{\frac {x}{r}}\right)^{-\beta }}{x^{\alpha }}}}$

where each of A(x) and B(x) is a function that is analytic to a radius of convergence greater than r (or is entire), and where B(r) ≠ 0 then

${\displaystyle a_{n}\sim {\frac {B(r)}{r^{\alpha }}}\left(\!\!{\binom {\beta }{n}}\!\!\right)(1/r)^{n}={\frac {B(r)}{r^{\alpha }}}{\binom {n+\beta -1}{n}}(1/r)^{n}\sim {\frac {B(r)}{r^{\alpha }\Gamma (\beta )}}\,n^{\beta -1}(1/r)^{n}\,,}$

using a multiset coefficient, a binomial coefficient, or the Gamma function.

Often this approach can be iterated to generate several terms in an asymptotic series for an. In particular,

${\displaystyle G\left(a_{n}-{\frac {B(r)}{r^{\alpha }}}{\binom {n+\beta -1}{n}}(1/r)^{n},x\right)=G(a_{n};x)-{\frac {B(r)}{r^{\alpha }}}\left(1-{\frac {x}{r}}\right)^{-\beta }\,.}$

The asymptotic growth of the coefficients of this generating function can then be sought via the finding of A, B, α, β, and r to describe the generating function, as above.

Similar asymptotic analysis is possible for exponential generating functions. With an exponential generating function, it is an/n! that grows according to these asymptotic formulae.

#### Asymptotic growth of the sequence of squares

As derived above, the ordinary generating function for the sequence of squares is

${\displaystyle {\frac {x(x+1)}{(1-x)^{3}}}.}$

With r = 1, α = 0, β = 3, A(x) = 0, and B(x) = x(x+1), we can verify that the squares grow as expected, like the squares:

${\displaystyle a_{n}\sim {\frac {B(r)}{r^{\alpha }\Gamma (\beta )}}\,n^{\beta -1}\left({\frac {1}{r}}\right)^{n}={\frac {1(1+1)}{1^{0}\,\Gamma (3)}}\,n^{3-1}(1/1)^{n}=n^{2}.}$

#### Asymptotic growth of the Catalan numbers

Main article: Catalan number

The ordinary generating function for the Catalan numbers is

${\displaystyle {\frac {1-{\sqrt {1-4x}}}{2x}}.}$

With r = 1/4, α = 1, β = −1/2, A(x) = 1/2, and B(x) = −1/2, we can conclude that, for the Catalan numbers,

${\displaystyle a_{n}\sim {\frac {B(r)}{r^{\alpha }\Gamma (\beta )}}\,n^{\beta -1}\left({\frac {1}{r}}\right)^{n}={\frac {-{\frac {1}{2}}}{({\frac {1}{4}})^{1}\Gamma (-{\frac {1}{2}})}}\,n^{-{\frac {1}{2}}-1}\left({\frac {1}{\frac {1}{4}}}\right)^{n}={\frac {1}{\sqrt {\pi }}}n^{-{\frac {3}{2}}}\,4^{n}.}$

### Bivariate and multivariate generating functions

One can define generating functions in several variables for arrays with several indices. These are called multivariate generating functions or, sometimes, super generating functions. For two variables, these are often called bivariate generating functions.

For instance, since ${\displaystyle (1+x)^{n}}$ is the ordinary generating function for binomial coefficients for a fixed n, one may ask for a bivariate generating function that generates the binomial coefficients ${\displaystyle {\binom {n}{k}}}$ for all k and n. To do this, consider ${\displaystyle (1+x)^{n}}$ as itself a series, in n, and find the generating function in y that has these as coefficients. Since the generating function for ${\displaystyle a^{n}}$ is

${\displaystyle {\frac {1}{1-ay}},}$

the generating function for the binomial coefficients is:

${\displaystyle \sum _{n,k}{\binom {n}{k}}x^{k}y^{n}={\frac {1}{1-(1+x)y}}={\frac {1}{1-y-xy}}.}$

## Examples

Generating functions for the sequence of square numbers an = n2 are:

### Ordinary generating function

${\displaystyle G(n^{2};x)=\sum _{n=0}^{\infty }n^{2}x^{n}={\frac {x(x+1)}{(1-x)^{3}}}}$

### Exponential generating function

${\displaystyle \operatorname {EG} (n^{2};x)=\sum _{n=0}^{\infty }{\frac {n^{2}x^{n}}{n!}}=x(x+1)e^{x}}$

### Bell series

${\displaystyle \operatorname {BG} _{p}(n^{2};x)=\sum _{n=0}^{\infty }(p^{n})^{2}x^{n}={\frac {1}{1-p^{2}x}}}$

### Dirichlet series generating function

${\displaystyle \operatorname {DG} (n^{2};s)=\sum _{n=1}^{\infty }{\frac {n^{2}}{n^{s}}}=\zeta (s-2),}$

using the Riemann zeta function.

The sequence an generated by a Dirichlet series generating function corresponding to:

${\displaystyle \operatorname {DG} (a_{n};s)=\zeta (s)^{m}}$

where ${\displaystyle \zeta (s)}$ is the Riemann zeta function, has the ordinary generating function:

${\displaystyle \sum _{n=1}^{\infty }a_{n}x^{n}=x+{m \choose 1}\sum _{a=2}^{\infty }x^{a}+{m \choose 2}\sum _{a=2}^{\infty }\sum _{b=2}^{\infty }x^{ab}+{m \choose 3}\sum _{a=2}^{\infty }\sum _{b=2}^{\infty }\sum _{c=2}^{\infty }x^{abc}+{m \choose 4}\sum _{a=2}^{\infty }\sum _{b=2}^{\infty }\sum _{c=2}^{\infty }\sum _{d=2}^{\infty }x^{abcd}+\cdots }$

### Multivariate generating function

Multivariate generating functions arise in practice when calculating the number of contingency tables of non-negative integers with specified row and column totals. Suppose the table has r rows and c columns; the row sums are ${\displaystyle t_{1},\ldots t_{r}}$ and the column sums are ${\displaystyle s_{1},\ldots s_{c}}$. Then, according to I. J. Good,[7] the number of such tables is the coefficient of

${\displaystyle x_{1}^{t_{1}}\ldots x_{r}^{t_{r}}y_{1}^{s_{1}}\ldots y_{c}^{s_{c}}}$

in

${\displaystyle \prod _{i=1}^{r}\prod _{j=1}^{c}{\frac {1}{1-x_{i}y_{j}}}.}$

## Applications

### Techniques of evaluating sums with generating function

Generating functions give us several methods to manipulate sums and to establish identities between sums.

The simplest case occurs when ${\displaystyle s_{n}=\sum _{k=0}^{n}{a_{k}}}$. We then know that ${\displaystyle S(z)={\frac {A(z)}{1-z}}}$ for the corresponding ordinary generating functions.

For example, we can manipulate ${\displaystyle s_{n}=\sum _{k=1}^{n}H_{k}}$, where ${\displaystyle H_{k}=1+{\frac {1}{2}}+\cdots +{\frac {1}{k}}}$ are the harmonic numbers. Let ${\displaystyle H(z)=\sum _{n\geq 1}{H_{n}z^{n}}}$ be the ordinary generating function of the harmonic numbers. Then

${\displaystyle H(z)={\dfrac {\sum _{n\geq 1}{{\frac {1}{n}}z^{n}}}{1-z}}\,,}$

and thus

${\displaystyle S(z)=\sum _{n\geq 1}{s_{n}z^{n}}={\dfrac {\sum _{n\geq 1}{{\frac {1}{n}}z^{n}}}{(1-z)^{2}}}\,.}$

Using ${\displaystyle {\frac {1}{(1-z)^{2}}}=\sum _{n\geq 0}{(n+1)z^{n}}}$, convolution with the numerator yields

${\displaystyle s_{n}=\sum _{k=1}^{n}{{\frac {1}{k}}(n+1-k)}=(n+1)H_{n}-n\,,}$

which can also be written as

${\displaystyle \sum _{k=1}^{n}{H_{k}}=(n+1)(H_{n+1}-1)\,.}$

### Convolution

1.Consider A(z) and B(z) are ordinary generating functions.
${\displaystyle C(z)=A(z)B(z)\Leftrightarrow [z^{n}]C(z)=\sum _{k=0}^{n}{a_{k}b_{n-k}}}$
2.Consider A(z) and B(z) are exponential generating functions.
${\displaystyle C(z)=A(z)B(z)\Leftrightarrow [z^{n}/n!]C(z)=\sum _{k=0}^{n}{{\binom {n}{k}}a_{k}b_{n-k}}}$

### Free parameter

Sometimes the sum ${\displaystyle s_{n}}$ is complicated, and it is not always easy to evaluate. The "Free Parameter" method is another method (called "snake oil" by H. Wilf) to evaluate these sums.

Both methods discussed so far have ${\displaystyle n}$ as limit in the summation. When n does not appear explicitly in the summation, we may consider ${\displaystyle n}$ as a “free” parameter and treat ${\displaystyle s_{n}}$ as a coefficient of ${\displaystyle F(z)=\sum {s_{n}z^{n}}}$, change the order of the summations on ${\displaystyle n}$ and ${\displaystyle k}$, and try to compute the inner sum.

For example, if we want to compute

${\displaystyle s_{n}=\sum _{k\geq 0}{{\binom {n+k}{m+2k}}{\binom {2k}{k}}{\frac {(-1)^{k}}{k+1}}}\quad (m,n\in \mathbb {N} _{0})}$

we can treat ${\displaystyle n}$ as a "free" parameter, and set

${\displaystyle F(z)=\sum _{n\geq 0}{\left[\sum _{k\geq 0}{{\binom {n+k}{m+2k}}{\binom {2k}{k}}{\frac {(-1)^{k}}{k+1}}}\right]}z^{n}}$

Interchanging summation (“snake oil”) gives

${\displaystyle F(z)=\sum _{k\geq 0}{{\binom {2k}{k}}{\frac {(-1)^{k}}{k+1}}z^{-k}}\sum _{n\geq 0}{{\binom {n+k}{m+2k}}z^{n+k}}}$

Now the inner sum is ${\displaystyle {\frac {z^{m+2k}}{(1-z)^{m+2k+1}}}}$. Thus

{\displaystyle {\begin{aligned}F(z)&={\frac {z^{m}}{(1-z)^{m+1}}}\sum _{k\geq 0}{{\frac {1}{k+1}}{\binom {2k}{k}}({\frac {-z}{(1-z)^{2}}})^{k}}\\&={\frac {z^{m}}{(1-z)^{m+1}}}\sum _{k\geq 0}{C_{k}({\frac {-z}{(1-z)^{2}}})^{k}}\quad {\rm {(where,C_{k}\,=\,k^{th}\,Catalan\,number)}}\\&={\frac {z^{m}}{(1-z)^{m+1}}}{\frac {1-{\sqrt {1+{\frac {4z}{(1-z)^{2}}}}}}{\frac {-2z}{(1-z)^{2}}}}\\&={\frac {-z^{m-1}}{2(1-z)^{m-1}}}(1-{\frac {1+z}{1-z}})\\&={\frac {z^{m}}{(1-z)^{m}}}=z{\frac {z^{m-1}}{(1-z)^{m}}}.\end{aligned}}}

Then we obtain

${\displaystyle s_{n}={\binom {n-1}{m-1}}\quad for\quad m\geq 1\quad ,\quad s_{n}=[n=0]\quad for\quad m=0.}$

### Other Applications

Generating functions are used to:

• Find a closed formula for a sequence given in a recurrence relation. For example, consider Fibonacci numbers.
• Find recurrence relations for sequences—the form of a generating function may suggest a recurrence formula.
• Find relationships between sequences—if the generating functions of two sequences have a similar form, then the sequences themselves may be related.
• Explore the asymptotic behaviour of sequences.
• Prove identities involving sequences.
• Solve enumeration problems in combinatorics and encoding their solutions. Rook polynomials are an example of an application in combinatorics.
• Evaluate infinite sums.

## Other generating functions

Examples of polynomial sequences generated by more complex generating functions include:

Other sequences generated by more complex generating functions:

## History

The name "generating function" is due to Laplace. Yet, without giving it a name, Euler used the device of generating functions long before Laplace [..]. He applied this mathematical tool to several problems in Combinatory Analysis and the Theory of Numbers.