![]() | ||
Brief history from analysis of algorithms to analytic combinatorics robert sedgewick
In mathematics, analytic combinatorics is one of the many techniques of counting combinatorial objects. It uses the internal structure of the objects to derive formulas for their generating functions and then complex analysis techniques to get asymptotics. This particular theory was mostly developed by Philippe Flajolet, and is detailed in his book with Robert Sedgewick, Analytic Combinatorics. Earlier contributors to the key ideas and techniques include Leonhard Euler, Arthur Cayley, Srinivasa Ramanujan, George Pólya, and Donald Knuth.
Contents
- Brief history from analysis of algorithms to analytic combinatorics robert sedgewick
- Introduction to analytic combinatorics part i with robert sedgewick
- Classes of combinatorial structures
- The FlajoletSedgewick fundamental theorem
- The sequence operator S displaystyle mathfrak S
- The cycle operator C displaystyle mathfrak C
- The multisetset operator M P displaystyle mathfrak Mmathfrak P
- Procedure
- Combinatorial sum
- Unlabelled structures
- Product
- Sequence
- Set
- Multiset
- Other elementary constructions
- Examples
- Labelled structures
- Cycle
- Boxed product
- Example
- References
Introduction to analytic combinatorics part i with robert sedgewick
Classes of combinatorial structures
Consider the problem of distributing objects given by a generating function into a set of n slots, where a permutation group G of degree n acts on the slots to create an equivalence relation of filled slot configurations, and asking about the generating function of the configurations by weight of the configurations with respect to this equivalence relation, where the weight of a configuration is the sum of the weights of the objects in the slots. We will first explain how to solve this problem in the labelled and the unlabelled case and use the solution to motivate the creation of classes of combinatorial structures.
The Pólya enumeration theorem solves this problem in the unlabelled case. Let f(z) be the ordinary generating function (OGF) of the objects, then the OGF of the configurations is given by the substituted cycle index
In the labelled case we use an exponential generating function (EGF) g(z) of the objects and apply the Labelled enumeration theorem, which says that the EGF of the configurations is given by
We are able to enumerate filled slot configurations using either PET in the unlabelled case or the labelled enumeration theorem in the labelled case. We now ask about the generating function of configurations obtained when there is more than one set of slots, with a permutation group acting on each. Clearly the orbits do not intersect and we may add the respective generating functions. Suppose, for example, that we want to enumerate unlabelled sequences of length two or three of some objects contained in a set X. There are two sets of slots, the first one containing two slots, and the second one, three slots. The group acting on the first set is
where the term
Clearly we can assign meaning to any such power series of quotients (orbits) with respect to permutation groups, where we restrict the groups of degree n to the conjugacy classes
A class
where
In the following we will simplify our notation a bit and write e.g.
for the classes mentioned above.
The Flajolet–Sedgewick fundamental theorem
A theorem in the Flajolet–Sedgewick theory of symbolic combinatorics treats the enumeration problem of labelled and unlabelled combinatorial classes by means of the creation of symbolic operators that make it possible to translate equations involving combinatorial structures directly (and automatically) into equations in the generating functions of these structures.
Let
and
In the labelled case we have the additional requirement that X not contain elements of size zero. It will sometimes prove convenient to add one to
The power of this theorem lies in the fact that it makes it possible to construct operators on generating functions that represent combinatorial classes. A structural equation between combinatorial classes thus translates directly into an equation in the corresponding generating functions. Moreover in the labelled case it is evident from the formula that we may replace
The sequence operator S {\displaystyle {\mathfrak {S}}}
This operator corresponds to the class
and represents sequences, i.e. the slots are not being permuted and there is exactly one empty sequence. We have
and
The cycle operator C {\displaystyle {\mathfrak {C}}}
This operator corresponds to the class
i.e., cycles containing at least one object. We have
or
and
This operator, together with the set operator
The labelled even cycle operator
which yields
This implies that the labelled odd cycle operator
is given by
The multiset/set operator M / P {\displaystyle {\mathfrak {M}}/{\mathfrak {P}}}
The series is
i.e., the symmetric group is applied to the slots. This creates multisets in the unlabelled case and sets in the labelled case (there are no multisets in the labelled case because the labels distinguish multiple instances of the same object from the set being put into different slots). We include the empty set in both the labelled and the unlabelled case.
The unlabelled case is done using the function
so that
Evaluating
For the labelled case we have
In the labelled case we denote the operator by
Procedure
Typically, one starts with the neutral class
In this article, we will follow the convention of using script uppercase letters to denote combinatorial classes and the corresponding plain letters for the generating functions (so the class
There are two types of generating functions commonly used in symbolic combinatorics—ordinary generating functions, used for combinatorial classes of unlabelled objects, and exponential generating functions, used for classes of labelled objects.
It is trivial to show that the generating functions (either ordinary or exponential) for
Combinatorial sum
The restriction of unions to disjoint unions is an important one; however, in the formal specification of symbolic combinatorics, it is too much trouble to keep track of which sets are disjoint. Instead, we make use of a construction that guarantees there is no intersection (be careful, however; this affects the semantics of the operation as well). In defining the combinatorial sum of two sets
This is the operation that formally corresponds to addition.
Unlabelled structures
With unlabelled structures, an ordinary generating function (OGF) is used. The OGF of a sequence
Product
The product of two combinatorial classes
Using the definition of the OGF and some elementary algebra, we can show that
Sequence
The sequence construction, denoted by
In other words, a sequence is the neutral element, or an element of
Set
The set (or powerset) construction, denoted by
which leads to the relation
where the expansion
was used to go from line 4 to line 5.
Multiset
The multiset construction, denoted
This leads to the relation
where, similar to the above set construction, we expand
Other elementary constructions
Other important elementary constructions are:
The derivations for these constructions are too complicated to show here. Here are the results:
Examples
Many combinatorial classes can be built using these elementary constructions. For example, the class of plane trees (that is, trees embedded in the plane, so that the order of the subtrees matters) is specified by the recursive relation
In other words, a tree is a root node of size 1 and a sequence of subtrees. This gives
we solve for G(z) by multiplying
subtracting z and solving for G(z) using the quadratic formula gives
Another example (and a classic combinatorics problem) is integer partitions. First, define the class of positive integers
The OGF of
Now, define the set of partitions
The OGF of
Unfortunately, there is no closed form for
Labelled structures
An object is weakly labelled if each of its atoms has a nonnegative integer label, and each of these labels is distinct. An object is (strongly or well) labelled, if furthermore, these labels comprise the consecutive integers
With labelled structures, an exponential generating function (EGF) is used. The EGF of a sequence
Product
For labelled structures, we must use a different definition for product than for unlabelled structures. In fact, if we simply used the cartesian product, the resulting structures would not even be well labelled. Instead, we use the so-called labelled product, denoted
For a pair
To aid this development, let us define a function,
Finally, the labelled product of two classes
The EGF can be derived by noting that for objects of size
This binomial convolution relation for the terms is equivalent to multiplying the EGFs,
Sequence
The sequence construction
and again, as above,
Set
In labelled structures, a set of
Cycle
Cycles are also easier than in the unlabelled case. A cycle of length
Boxed product
In labelled structures, the min-boxed product
or equivalently,
Example
An increasing Cayley tree is a labelled non-plane and rooted tree whose labels along any branch stemming from the root form an increasing sequence. Then, let
Other elementary constructions
The operators
represent cycles of even and odd length, and sets of even and odd cardinality.
Example
Stirling numbers of the second kind may be derived and analyzed using the structural decomposition
The decomposition
is used to study unsigned Stirling numbers of the first kind, and in the derivation of the statistics of random permutations. A detailed examination of the exponential generating functions associated to Stirling numbers within symbolic combinatorics may be found on the page on Stirling numbers and exponential generating functions in symbolic combinatorics.