Busy Beaver for lambda calculus
Busy Beaver for lambda calculus (BBλ) is a variation of the Busy Beaver problem for lambda calculus invented by John Tromp. BBλ(n) = the maximum normal form size of any closed lambda term of size n. Like the traditional Busy Beaver functions, it is uncomputable (and in fact grows faster than any computable function). If you are not familiar with lambda calculus and beta-reduction, it is recommended to start with that article.
Size is measured in bits using Binary Lambda Calculus which is a binary prefix-free encoding for all closed lambda calculus terms.
Analogy to Turing machines
We evaluate terms by applying beta-reductions until they reach a normal form. As an analogy to Turing machines:
- Lambda terms are like TM configurations (tape + state + position).
- Applying beta-reduction to a term is like taking a TM step.
- A term is in normal form if no beta-reductions can be applied. This is like saying the term has halted.
- A term may or may not be reducible to a normal form. If it is, this is like saying the term halts.
- Determining whether a term is reducible to a normal form is an undecidable problem equivalent to the halting problem.
Note: That unlike for Turing machines, evaluating lambda terms is non-deterministic. Specifically, there may be multiple beta-reductions possible in a given term. However, if a term can be reduced to a normal form, that normal form is unique. It is not possible to reduce the original term to any different normal form. A term is strongly normalizing if any choice of beta-reductions will lead to this normal form and weakly normalizing if there exist divergent reduction paths which never reach the normal form.
Proof of Uncomputability
The proof that BBλ(n) is uncomputable is very similar to Radó's original proof that Σ(n) is uncomputable. Proof by contradiction:
Assume BBλ is computable and so there exists a term f which computes it on Church numerals. In other words: for all : beta reduces to normal form (where denotes the Church numeral n). Denote the binary lambda encoded size of f as k. Consider the term which has size bits. This term reduces to which has size bits. But for sufficiently large n, and so . But this is a contradiction, we've found a bit term which reduces to a normal form larger than .
Thus BBλ(n) is uncomputable. A variation of this argument shows that BBλ(n) eventually dominates all computable functions.
Binary Lambda Encoding
A lambda term using De Bruijn indexes is defined inductively as:
- Variables: For any , Var(n) is a term. It represents a variable bound by the lambda expression n above this one (the De Bruijn index). It is typically written simply as n.
- Lambdas: For any term T, Lam(T) is a term. It represents a unary function with function body T. It is typically written  or \T.
- Applications: For any terms T, U, App(T, U) is a term. It represents applying function T to argument U. It is typically written (T U).
We can think of this as a tree where each variable is a leaf, a lambda is a node with one child and applications are nodes with 2 children. A term is closed if every variable is bound. In other words, for every Var(n) leaf node, there exists n Lam() nodes above it in the tree of the term.
Encoding (blc()) is defined recursively:
For example, the Church numeral 2:  =  \\(2 (2 1)) = Lam(Lam(App(Var(2), App(Var(2), Var(1)))) is encoded as 00 00 01 110 01 110 10 or simply 0000011100111010 (spaces are not part of the encoding, only used for demonstration purposes) and thus has size 16 bits.
Text Encoding conventions
For human readability, a text encoding and set of conventions is used in this article. As described earlier we encode a lambda term as:
- Var(n) -> n
- Lam(T) -> (\T)
- App(T, U) -> (T U)
However, parentheses are also dropped in certain cases by convention:
- The outermost parentheses are dropped: Lam(1)->\1andApp(1, 2)->1 2.
- Parentheses are dropped immediately inside a Lam: Lam(Lam(1))->\\1andLam(App(1, 1))->\1 1.
- Parentheses are dropped in nested Apps using left associativity: App(App(1, 2), 3)->1 2 3. (Note: parentheses are still required forApp(1, App(2, 3))->1 (2 3)).
This is the convention used in John Tromp's code and so is used here for consistency.
Champions
There are no closed lambda terms of size 0, 1, 2, 3 or 5 and so BBλ(n) is not defined for those values. The smallest closed lambda term is \1 which has size 4.
For the rest of n ≤ 20: BBλ(n) = n is trivial and can be achieved via picking any n bit term already in normal form. For example \\...\1 and \\...\2 with k lambdas has size 2k+2 and 2k+3 respectively (for k ≥ 1 and k ≥ 2 respectively).
| n | BBλ(n) | Champion | # Beta reductions | Normal form | Discovered By | 
|---|---|---|---|---|---|
| 21 | = 22 | \(\1 1) (1 (\2)) | 1 | \(1 (\2)) (1 (\2)) | John Tromp & Bertram Felgenhauer | 
| 22 | = 24 | \(\1 1) (1 (\\1))\(\1 1 1) (1 1) | 1 1 | \(1 (\\1)) (1 (\\1))\(1 1) (1 1) (1 1) | John Tromp & Bertram Felgenhauer | 
| 23 | = 26 | \(\1 1) (1 (\\2)) | 1 | \(1 (\\2)) (1 (\\2)) | John Tromp & Bertram Felgenhauer | 
| 24 | = 30 | \(\1 1 1) (1 (\1)) | 1 | \(1 (\1)) (1 (\1)) (1 (\1)) | John Tromp & Bertram Felgenhauer | 
| 25 | = 42 | \(\1 1) (\1 (2 1)) | 3 | \1 (\1 (2 1)) (1 (1 (\1 (2 1)))) | John Tromp & Bertram Felgenhauer | 
| 26 | = 52 | (\1 1) (\\2 (1 2)) | 3 | \\2 (\\2 (1 2)) (1 (2 (\\2 (1 2)))) | John Tromp & Bertram Felgenhauer | 
| 27 | = 44 | \\(\1 1) (\1 (2 1)) | 3 | \\1 (\1 (2 1)) (1 (1 (\1 (2 1)))) | John Tromp & Bertram Felgenhauer | 
| 28 | = 58 | \(\1 1) (\1 (2 (\2)))) | 3 | \1 (\\1 (3 (\2))) (1 (\2 (\\1 (4 (\2))))) | John Tromp & Bertram Felgenhauer | 
| 29 | = 223 | \(\1 1) (\1 (1 (2 1))) | 4 | \B (B (1 B))
  where:
    B = (A (A (1 A)))
    A = (1 (\1 (1 (2 1))))
 | John Tromp & Bertram Felgenhauer | 
| 30 | = 160 | (\1 1 1) (\\2 (1 2))and
 | 7 5 | \\2 B A (1 (2 B A))
  where:
    B = (\\2 A (1 (2 A)))
    A = (\\2 (1 2))
 | John Tromp & Bertram Felgenhauer | 
| 31 | = 267 | (\1 1) (\\2 (2 (1 2))) | 6 | \\2 A (2 A (C (2 A)))
  where:
    C = (2 A (2 A (1 B (2 A))))
    B = (\3 A (3 A (1 (3 A))))
    A = (\\2 (2 (1 2)))
 | John Tromp & Bertram Felgenhauer | 
| 32 | = 298 | \(\1 1) (\1 (1 (2 (\2)))) | John Tromp & Bertram Felgenhauer | ||
| 33 | = 1812 | \(\1 1) (\1 (1 (1 (2 1)))) | 5 | \C (C (C (1 C)))
  where:
    C = (B (B (B (1 B)))
    B = (A (A (A (1 A)))
    A = (1 (\1 (1 (1 (2 1)))))
 | John Tromp & Bertram Felgenhauer | 
| 34 | (\1 1 1 1) (\\2 (2 1))and
 | John Tromp & Bertram Felgenhauer | |||
| 35 | (\1 1 1) (\\2 (2 (2 1))) | John Tromp & Bertram Felgenhauer | |||
| 36 | (\1 1) (\1 (1 (\\2 (2 1)))) | John Tromp & Bertram Felgenhauer | |||
| 37 | \(\1 1 1) (\\2 (2 (2 1))) | mxdys, tromp, dyuan, sligocki | |||
| 38 | (\1 1 1 1 1) (\\2 (2 1))and
 | John Tromp & Bertram Felgenhauer | |||
| 39 | (\1 1 1 1) (\\2 (2 (2 1))) | John Tromp & Bertram Felgenhauer | |||
| 40 | (\1 1 1) (\1 (\\2 (2 1)) 1) | where and | mxdys and racheline | ||
| 41 | (\1 (\1 1) 1) (\\2 (2 (2 1))) | mxdys | |||
| 42 | \(\1 1 1) (\1 (\\2 (2 1)) 1) | ||||
| 43 | (\1 1) (\1 (\1 (\\2 (2 1)) 2)) | where and | mxdys | ||
| 44 | (\1 1 1 1) (\1 (\\2 (2 1)) 1) | where and | |||
| 45 | \(\1 1) (\1 (\1 (\\2 (2 1)) 2)) | ||||
| 46 | \(\1 1 1 1) (\1 (\\2 (2 1)) 1) | ||||
| 47 | |||||
| 48 | (\1 1 1 1 1) (\1 (\\2 (2 1)) 1) | where and | |||
| 49 | (\1 1) (\1 (1 (\\1 2 (\\2 (2 1))))) | Gustavo Melo | |||
| ... | |||||
| 1850 | > Loader's number | too large to show | John Tromp | 
Where  represents the Church numeral n () written as \\2 (2 ... (2 1)...) with n 2s in this text representation.
Oracle Busy Beaver
While BBλ grows uncomputably fast, one can define functions that grow much faster.
Let's define a higher order busy beaver function BBλ1 by providing oracle access to BBλ.
This is done by enriching the set of terms and possible reduction steps considered in the BB definition.
A 1-closed term is a term in de Bruijn notation that is closed with 1 additional lambda in front. Any variable bound to that lambda is a free variable f in the term.
An oracle reduction step reduces f t, where t is a closed normal form of size s, to Church numeral BB(s).
Note that this is almost identical to the oracle steps in Barendregt and Klop's "Applications of infinitary lambda calculus", except that they require t itself to be a church numeral. Allowing arbitrary closed t makes oracle steps more widely applicable while aligning with BBλ's focus on term sizes.
Now let BBλ1 be the maximum beta/oracle normal form size of any 1-closed lambda term of size n, or 0 if no 1-closed term of size n exists. This appears as sequence A385712 in the OEIS.
The following table shows values of BBλ1 up to 22 plus a lower bound for 28, with larger values expressed in terms of function :
| n | champion | BBλ1 | 
|---|---|---|
| 1 | 0 | |
| 2 | 1 | 1 | 
| 3 | 0 | |
| 4 | \1 | 4 | 
| 5 | \2 | 5 | 
| 6 | \\1 | 6 | 
| 7 | \\2 | 7 | 
| 8 | 1 (\1) | |
| 9 | \\2 | 9 | 
| 10 | 1 (\\1) | |
| 11 | 1 (\\2) | |
| 12 | 1 (1 (\1)) | |
| 13 | 1 (\\2) | |
| 14 | 1 (1 (\\1)) | |
| 15 | 1 (1 (\\2)) | |
| 16 | 1 (1 (1 (\1))) | |
| 17 | 1 (1 (\\\2)) | |
| 18 | 1 (\1) 1 (\1) | |
| 19 | 1 (1 (1 (\\2))) | |
| 20 | 1 (\\1) 1 (\1) | |
| 21 | 1 (\\2) 1 (\1) | |
| 22 | 1 (1 (\1)) 1 (\1) | |
| ... | ||
| 28 | 1 (\1) 1 (\1) 1 (\1) | 
We can generalize BBλ1 to BBλα for ordinals α by using oracle function BBλα-1 for successor ordinal a, and oracle function (\n -> BBλα[n](n)) for limit ordinal α, assuming well-defined fundamental sequences up to α. Because of limited oracle inputs, all oracle busy beavers have identical values up to n=11.
See Also
- https://oeis.org/A333479
- The largest number representable in 64 bits. 24 Nov 2023. John Tromp.
- Binary Lambda Calculus. John Tromp.
- https://github.com/tromp/AIT/tree/master/BB