aboutsummaryrefslogtreecommitdiffhomepage
path: root/std/Number/Bruijn.bruijn
blob: 585d3bc998afb77065c3d6dc8bfad2d204d8f7dc (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
# 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

# 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))