aboutsummaryrefslogtreecommitdiffhomepage
path: root/std/Number/Bruijn.bruijn
diff options
context:
space:
mode:
Diffstat (limited to 'std/Number/Bruijn.bruijn')
-rw-r--r--std/Number/Bruijn.bruijn23
1 files changed, 23 insertions, 0 deletions
diff --git a/std/Number/Bruijn.bruijn b/std/Number/Bruijn.bruijn
new file mode 100644
index 0000000..744d9a1
--- /dev/null
+++ b/std/Number/Bruijn.bruijn
@@ -0,0 +1,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))