Church Numbers are the union of natural numbers
which are represented by lambda functions
.
Math
Think that we need to use function to represent numbers, what method should we take?
The way to describe numbers by church numbers is that:
$0:x$
$1:f(x)$
and so on
So we can use codes to represent them easily by just call the function we need for the numbers times.
Code
First we need two functions in order to identify the other natural numbers:
1 | def zero(f): |
It is not hard to find that:
1 | one = successor(zero) |
As you can see here, if we pass zero
or one
this church numbers into the successor()
, we will finally get the number after them.
And also, there is a more interesting conclusion here, is that:
1 | zero(f)(x) -> x |
It means that n(f)(x) == x
.
So we can simply describe all the natural numbers by lambda functions.
1 | def one(f): |
Then how can we transform them to int?
By the code before, we will find that if we do like two()
, it actually do twice of the passing parameter f
.
So if we got a function that increase each time when we call it, and initialize it parameter to 0, it will be fine!
1 | def church_to_int(n): |
We can just only use simple rules like this below to accomplish the goal:
1 | def add_church(m, n): |
But here is a more advanced version:
1 | def add_church(m, n): |
Myself just finished the basic version and this version above is quite ingenious.
Here is the link: Church numbers.