aboutsummaryrefslogtreecommitdiffhomepage
path: root/std/Number/Bruijn.bruijn
blob: 744d9a16e642e75e80f82e69b915d7c96039f21e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# MIT License, Copyright (c) 2023 Marvin Borner
# De Bruijn numeral system (named by me)
# proof that this numeral system does not support zero/eq/sub/etc. is in
#   Wadsworth, Christopher. "Some unusual λ-calculus numeral systems."
# very sad indeed

:import std/Combinator . 

# increments De Bruijn numeral
inc [[[2 1]]]

++‣ inc

:test (++(+0d)) ((+1d))
:test (++(+5d)) ((+6d))

# decrements De Bruijn numeral
dec [[1 0 0]]

--‣ dec

:test (--(+1d)) ((+0d))
:test (--(+5d)) ((+4d))