aboutsummaryrefslogtreecommitdiffhomepage
path: root/std
diff options
context:
space:
mode:
Diffstat (limited to 'std')
-rw-r--r--std/Combinator.bruijn330
-rw-r--r--std/List.bruijn46
-rw-r--r--std/Logic.bruijn4
-rw-r--r--std/Pair.bruijn23
4 files changed, 204 insertions, 199 deletions
diff --git a/std/Combinator.bruijn b/std/Combinator.bruijn
index 115ea93..6b0eaed 100644
--- a/std/Combinator.bruijn
+++ b/std/Combinator.bruijn
@@ -2,238 +2,238 @@
# Inspired by Raymond Smullyan: To Mock a Mockingbird
# -> bird monickered combinators (they're still quite useful though!)
-# Apply combinator
-A [[1 0]]
+# apply combinator
+a [[1 0]]
-($) A
+($) a
-# Bluebird combinator: 1 <- 1 composition
-B [[[2 (1 0)]]]
+# bluebird combinator: 1 <- 1 composition
+b [[[2 (1 0)]]]
-(.) B
+(.) b
-# Blackbird combinator
-B' [[[[3 (2 1 0)]]]]
+# blackbird combinator
+b' [[[[3 (2 1 0)]]]]
-(..) B'
+(..) b'
-# Bunting combinator
-B'' [[[[[4 (3 2 1 0)]]]]]
+# bunting combinator
+b'' [[[[[4 (3 2 1 0)]]]]]
-(...) B''
+(...) b''
-# Becard combinator
-B''' [[[[3 (2 (1 0))]]]]
+# becard combinator
+b''' [[[[3 (2 (1 0))]]]]
-# Cardinal combinator: Reverse arguments
-C [[[2 0 1]]]
+# cardinal combinator: reverse arguments
+c [[[2 0 1]]]
-\( C
+\( c
-# Cardinal once removed combinator
-C* [[[[3 2 0 1]]]]
+# cardinal once removed combinator
+c* [[[[3 2 0 1]]]]
-# Cardinal twice removed combinator
-C** [[[[[4 3 2 0 1]]]]]
+# cardinal twice removed combinator
+c** [[[[[4 3 2 0 1]]]]]
-# Dove combinator
-D [[[[3 2 (1 0)]]]]
+# dove combinator
+d [[[[3 2 (1 0)]]]]
-# Dickcissel combinator
-D' [[[[[4 3 2 (1 0)]]]]]
+# dickcissel combinator
+d' [[[[[4 3 2 (1 0)]]]]]
-# Dovekies combinator
-D'' [[[[[4 (3 2) (1 0)]]]]]
+# dovekies combinator
+d'' [[[[[4 (3 2) (1 0)]]]]]
-# Eagle combinator
-E [[[[[4 3 (2 1 0)]]]]]
+# eagle combinator
+e [[[[[4 3 (2 1 0)]]]]]
-# Bald eagle combinator
-E' [[[[[[[6 (5 4 3) (2 1 0)]]]]]]]
+# bald eagle combinator
+e' [[[[[[[6 (5 4 3) (2 1 0)]]]]]]]
-# Finch combinator
-F [[[0 1 2]]]
+# finch combinator
+f [[[0 1 2]]]
-# Finch once removed combinator
-F* [[[[3 0 1 2]]]]
+# finch once removed combinator
+f* [[[[3 0 1 2]]]]
-# Finch twice removed combinator
-F** [[[[[4 3 0 1 2]]]]]
+# finch twice removed combinator
+f** [[[[[4 3 0 1 2]]]]]
-# Goldfinch combinator
-G [[[[3 0 (2 1)]]]]
+# goldfinch combinator
+g [[[[3 0 (2 1)]]]]
-# Hummingbird combinator
-H [[[2 1 0 1]]]
+# hummingbird combinator
+h [[[2 1 0 1]]]
-# Idiot combinator: Identity
-I [0]
+# idiot combinator: identity
+i [0]
-# Idiot once removed combinator
-I* [[1 0]]
+# idiot once removed combinator
+i* [[1 0]]
-# Idiot twice removed combinator
-I** [[[2 1 0]]]
+# idiot twice removed combinator
+i** [[[2 1 0]]]
-# Jay combinator
-J [[[[3 2 (3 0 1)]]]]
+# jay combinator
+j [[[[3 2 (3 0 1)]]]]
-# Kestrel combinator: Const, True
-K [[1]]
+# kestrel combinator: const, true
+k [[1]]
-# Kite combinator: Const id, False
-KI [[0]]
+# kite combinator: const id, false
+ki [[0]]
-# Konstant mocker combinator
-KM [[0 0]]
+# konstant mocker combinator
+km [[0 0]]
-# Crossed konstant mocker combinator
-KM' [[1 1]]
+# crossed konstant mocker combinator
+km' [[1 1]]
-# Lark combinator
-L [[1 (0 0)]]
+# lark combinator
+l [[1 (0 0)]]
-# Mockingbird/omega combinator
-M [0 0]
+# mockingbird/omega combinator
+m [0 0]
-ω M
+ω m
-# Double mockingbird combinator
-M' [[1 0 (1 0)]]
+# double mockingbird combinator
+m' [[1 0 (1 0)]]
-# Owl combinator
-O [[0 (1 0)]]
+# owl combinator
+o [[0 (1 0)]]
-# Omega combinator
+# omega combinator
Ω ω ω
-# Phoenix combinator
-Φ [[[[3 (2 0) (1 0)]]]]
+# phoenix combinator
+φ [[[[3 (2 0) (1 0)]]]]
-# Psi combinator: On
-Ψ [[[[3 (2 1) (2 0)]]]]
+# psi combinator: on
+ψ [[[[3 (2 1) (2 0)]]]]
-# Queer combinator
-Q [[[1 (2 0)]]]
+# queer combinator
+q [[[1 (2 0)]]]
-(>>>) Q
+(>>>) q
-# Quixotic bird combinator
-Q' [[[2 (0 1)]]]
+# quixotic bird combinator
+q' [[[2 (0 1)]]]
-# Quizzical bird combinator
-Q'' [[[1 (0 2)]]]
+# quizzical bird combinator
+q'' [[[1 (0 2)]]]
-# Quirky bird combinator
-Q''' [[[0 (2 1)]]]
+# quirky bird combinator
+q''' [[[0 (2 1)]]]
-# Quacky bird combinator
-Q'''' [[[0 (1 2)]]]
+# quacky bird combinator
+q'''' [[[0 (1 2)]]]
-# Robin combinator
-R [[[1 0 2]]]
+# robin combinator
+r [[[1 0 2]]]
-# Robin once removed combinator
-R* [[[[3 1 0 2]]]]
+# robin once removed combinator
+r* [[[[3 1 0 2]]]]
-# Robin twice removed combinator
-R** [[[[[4 3 1 0 2]]]]]
+# robin twice removed combinator
+r** [[[[[4 3 1 0 2]]]]]
-# Starling combinator: <*>
-S [[[2 0 (1 0)]]]
+# starling combinator: <*>
+s [[[2 0 (1 0)]]]
-# Thrush combinator: Flipped $
-T [[0 1]]
+# thrush combinator: flipped $
+t [[0 1]]
-(&) T
+(&) t
-# Turing combinator
-U [[0 (1 1 0)]]
+# turing combinator
+u [[0 (1 1 0)]]
-# Vireo combinator
-V [[[0 2 1]]]
+# vireo combinator
+v [[[0 2 1]]]
-# Vireo once removed combinator
-V* [[[[3 0 2 1]]]]
+# vireo once removed combinator
+v* [[[[3 0 2 1]]]]
-# Vireo twice removed combinator
-V** [[[[[4 3 0 2 1]]]]]
+# vireo twice removed combinator
+v** [[[[[4 3 0 2 1]]]]]
-# Warbler combinator
-W [[1 0 0]]
+# warbler combinator
+w [[1 0 0]]
-# Warbler once removed combinator
-W* [[[2 1 0 0]]]
+# warbler once removed combinator
+w* [[[2 1 0 0]]]
-# Warbler twice removed combinator
-W** [[[[3 2 1 0 0]]]]
+# warbler twice removed combinator
+w** [[[[3 2 1 0 0]]]]
-# Converse warbler combinator
-W' [[0 1 1]]
+# converse warbler combinator
+w' [[0 1 1]]
-# Sage bird combinator
-Y [[1 (0 0)] [1 (0 0)]]
+# sage bird combinator
+y [[1 (0 0)] [1 (0 0)]]
-# Z fixed point combinator
-Z [[1 [1 1 0]] [1 [1 1 0]]]
+# z fixed point combinator
+z [[1 [1 1 0]] [1 [1 1 0]]]
-# Theta combinator
-Θ [[0 (1 1 0)]] [[0 (1 1 0)]]
+# theta combinator
+θ [[0 (1 1 0)]] [[0 (1 1 0)]]
# iota combinator
-i [0 S K]
+ι [0 s k]
# -- combinator equivalency tests --
-:test (A) (S (S K))
-:test (B) (S (K S) K)
-:test (B') (B B B)
-:test (B'') (B (B B B) B)
-:test (B''') (B (B B) B)
-:test (C) (S (B B S) (K K))
-:test (C*) (B C)
-:test (C**) (B C*)
-:test (D) (B B)
-:test (D') (B (B B))
-:test (D'') (B B (B B))
-:test (E) (B (B B B))
-:test (E') (B (B B B) (B (B B B)))
-:test (F) (E T T E T)
-:test (F*) (B C* R*)
-:test (F**) (B F*)
-:test (G) (B B C)
-:test (H) (B W (B C))
-:test (I) (S K K)
-:test (I*) (S (S K))
-:test (J) (B (B C) (W (B C E)))
-:test (KI) (K I)
-:test (L) (C B M)
-:test (M) (S I I)
-:test (M') (B M)
-:test (O) (S I)
-:test (Q) (C B)
-:test (Q') (B C B)
-:test (Q'') (C (B C B))
-:test (Q''') (B T)
-:test (Q'''') (F* B)
-:test (R) (B B T)
-:test (R*) (C* C*)
-:test (R**) (B R*)
-:test (T) (C I)
-:test (U) (L O)
-:test (V) (B C T)
-:test (V*) (C* F*)
-:test (V**) (B V*)
-:test (W) (C (B M R))
-:test (W*) (B W)
-:test (W**) (B (B W))
-:test (W') (C W)
+:test (a) (s (s k))
+:test (b) (s (k s) k)
+:test (b') (b b b)
+:test (b'') (b (b b b) b)
+:test (b''') (b (b b) b)
+:test (c) (s (b b s) (k k))
+:test (c*) (b c)
+:test (c**) (b c*)
+:test (d) (b b)
+:test (d') (b (b b))
+:test (d'') (b b (b b))
+:test (e) (b (b b b))
+:test (e') (b (b b b) (b (b b b)))
+:test (f) (e t t e t)
+:test (f*) (b c* r*)
+:test (f**) (b f*)
+:test (g) (b b c)
+:test (h) (b w (b c))
+:test (i) (s k k)
+:test (i*) (s (s k))
+:test (j) (b (b c) (w (b c e)))
+:test (ki) (k i)
+:test (l) (c b m)
+:test (m) (s i i)
+:test (m') (b m)
+:test (o) (s i)
+:test (q) (c b)
+:test (q') (b c b)
+:test (q'') (c (b c b))
+:test (q''') (b t)
+:test (q'''') (f* b)
+:test (r) (b b t)
+:test (r*) (c* c*)
+:test (r**) (b r*)
+:test (t) (c i)
+:test (u) (l o)
+:test (v) (b c t)
+:test (v*) (c* f*)
+:test (v**) (b v*)
+:test (w) (c (b m r))
+:test (w*) (b w)
+:test (w**) (b (b w))
+:test (w') (c w)
# -- iota and SKI tests --
-:test (I) (i i)
-:test (K) (i (i (i i)))
-:test (S) (i (i (i (i i))))
-:test (B) (S (K S) K)
-:test (C) (S (S (K (S (K S) K)) S) (K K))
-:test (W) (S S (S K))
+:test (i) (ι ι)
+:test (k) (ι (ι (ι ι)))
+:test (s) (ι (ι (ι (ι ι))))
+:test (b) (s (k s) k)
+:test (c) (s (s (k (s (k s) k)) s) (k k))
+:test (w) (s s (s k))
diff --git a/std/List.bruijn b/std/List.bruijn
index b84f5d0..891dc7c 100644
--- a/std/List.bruijn
+++ b/std/List.bruijn
@@ -42,7 +42,7 @@ tail P.snd
:test (~((+1) : ((+2) : empty))) ((+2) : empty)
# returns the length of a list in balanced ternary
-length Z [[[rec]]] (+0)
+length z [[[rec]]] (+0)
rec <>?0 case-end case-inc
case-inc 2 ++1 ~0
case-end 1
@@ -53,7 +53,7 @@ length Z [[[rec]]] (+0)
:test (#empty) ((+0))
# returns the element at index in list
-index Z [[[rec]]]
+index z [[[rec]]]
rec <>?0 case-end case-index
case-index =?1 ^0 (2 --1 ~0)
case-end empty
@@ -66,7 +66,7 @@ index Z [[[rec]]]
:test (((+1) : ((+2) : ((+3) : empty))) !! (+3)) (empty)
# applies a left fold on a list
-foldl Z [[[[rec]]]]
+foldl z [[[[rec]]]]
rec <>?0 case-end case-fold
case-fold 3 2 (2 1 ^0) ~0
case-end 1
@@ -78,7 +78,7 @@ foldl Z [[[[rec]]]]
foldl1 [[foldl 1 ^0 ~0]]
# applies a right fold on a list
-foldr [[[Z [[rec]] 0]]]
+foldr [[[z [[rec]] 0]]]
rec <>?0 case-end case-fold
case-fold 4 ^0 (1 ~0)
case-end 3
@@ -143,7 +143,7 @@ reverse foldl \cons empty
list [0 [[[2 (0 : 1)]]] reverse empty]
# appends two lists
-append Z [[[rec]]]
+append z [[[rec]]]
rec <>?1 case-end case-merge
case-merge ^1 : (2 ~1 0)
case-end 0
@@ -161,7 +161,7 @@ snoc [[1 ++ (0 : empty)]]
:test (((+1) : empty) ; (+2)) ((+1) : ((+2) : empty))
# maps each element to a function
-map Z [[[rec]]]
+map z [[[rec]]]
rec <>?0 case-end case-map
case-map (1 ^0) : (2 1 ~0)
case-end empty
@@ -171,9 +171,9 @@ map Z [[[rec]]]
:test (inc <$> ((+1) : ((+2) : ((+3) : empty)))) ((+2) : ((+3) : ((+4) : empty)))
# filters a list based on a predicate
-filter Z [[[rec]]]
+filter z [[[rec]]]
rec <>?0 case-end case-filter
- case-filter 1 ^0 (cons ^0) I (2 1 ~0)
+ case-filter 1 ^0 (cons ^0) i (2 1 ~0)
case-end empty
(<#>) \filter
@@ -181,7 +181,7 @@ filter Z [[[rec]]]
:test (((+1) : ((+0) : ((+3) : empty))) <#> zero?) ((+0) : empty)
# returns the last element of a list
-last Z [[rec]]
+last z [[rec]]
rec <>?0 case-end case-last
case-last <>?(~0) ^0 (1 ~0)
case-end empty
@@ -191,7 +191,7 @@ _( last
:test (last ((+1) : ((+2) : ((+3) : empty)))) ((+3))
# returns everything but the last element of a list
-init Z [[rec]]
+init z [[rec]]
rec <>?0 case-end case-init
case-init <>?(~0) empty (^0 : (1 ~0))
case-end empty
@@ -211,7 +211,7 @@ concat-map [foldr (append . 0) empty]
:test (concat-map [-0 : (0 : empty)] ((+1) : ((+2) : empty))) ((-1) : ((+1) : ((-2) : ((+2) : empty))))
# zips two lists discarding excess elements
-zip Z [[[rec]]]
+zip z [[[rec]]]
rec <>?1 case-end case-zip
case-zip <>?0 empty ((^1 : ^0) : (2 ~1 ~0))
case-end empty
@@ -219,7 +219,7 @@ zip Z [[[rec]]]
:test (zip ((+1) : ((+2) : empty)) ((+2) : ((+1) : empty))) (((+1) : (+2)) : (((+2) : (+1)) : empty))
# applies pairs of the zipped list as arguments to a function
-zip-with Z [[[[rec]]]]
+zip-with z [[[[rec]]]]
rec <>?1 case-end case-zip
case-zip <>?0 empty ((2 ^1 ^0) : (3 2 ~1 ~0))
case-end empty
@@ -227,7 +227,7 @@ zip-with Z [[[[rec]]]]
:test (zip-with (+) ((+1) : ((+2) : empty)) ((+2) : ((+1) : empty))) ((+3) : ((+3) : empty))
# returns first n elements of a list
-take Z [[[rec]]]
+take z [[[rec]]]
rec <>?0 case-end case-take
case-take =?1 empty (^0 : (2 --1 ~0))
case-end empty
@@ -235,7 +235,7 @@ take Z [[[rec]]]
:test (take (+2) ((+1) : ((+2) : ((+3) : empty)))) ((+1) : ((+2) : empty))
# takes elements while a predicate is satisfied
-take-while Z [[[rec]]]
+take-while z [[[rec]]]
rec <>?0 case-end case-take
case-take 1 ^0 (^0 : (2 1 ~0)) empty
case-end empty
@@ -243,7 +243,7 @@ take-while Z [[[rec]]]
:test (take-while zero? ((+0) : ((+0) : ((+1) : empty)))) ((+0) : ((+0) : empty))
# removes first n elements of a list
-drop Z [[[rec]]]
+drop z [[[rec]]]
rec <>?0 case-end case-drop
case-drop =?1 0 (2 --1 ~0)
case-end empty
@@ -251,7 +251,7 @@ drop Z [[[rec]]]
:test (drop (+2) ((+1) : ((+2) : ((+3) : empty)))) ((+3) : empty)
# removes elements from list while a predicate is satisfied
-drop-while Z [[[rec]]]
+drop-while z [[[rec]]]
rec <>?0 case-end case-drop
case-drop 1 ^0 (2 1 ~0) 0
case-end empty
@@ -259,7 +259,7 @@ drop-while Z [[[rec]]]
:test (drop-while zero? ((+0) : ((+0) : ((+1) : empty)))) ((+1) : empty)
# returns pair of take-while and drop-while
-span Z [[[rec]]]
+span z [[[rec]]]
rec <>?0 case-end case-drop
case-drop 1 ^0 ((^0 : ^recced) : ~recced) (empty : 0)
recced 2 1 ~0
@@ -298,7 +298,7 @@ eq? &&( ... zip-with
:test (eq? (=?) empty empty) (true)
# removes first element that match an eq predicate
-remove Z [[[[rec]]]]
+remove z [[[[rec]]]]
rec <>?0 case-end case-remove
case-remove (2 ^0 1) ~0 (^0 : (3 2 1 ~0))
case-end empty
@@ -306,7 +306,7 @@ remove Z [[[[rec]]]]
:test (remove (=?) (+2) ((+1) : ((+2) : ((+3) : ((+2) : empty))))) ((+1) : ((+3) : ((+2) : empty)))
# removes duplicates from list based on eq predicate (keeps first occurrence)
-nub Z [[[rec]]]
+nub z [[[rec]]]
rec <>?0 case-end case-nub
case-nub ^0 : (2 1 (~0 <#> [!(2 0 ^1)]))
case-end empty
@@ -315,7 +315,7 @@ nub Z [[[rec]]]
:test (nub (=?) ((+1) : ((+2) : ((+1) : empty)))) (((+1) : ((+2) : empty)))
# returns a list with infinite-times a element
-repeat Z [[rec]]
+repeat z [[rec]]
rec 0 : (1 0)
:test (take (+3) (repeat (+4))) ((+4) : ((+4) : ((+4) : empty)))
@@ -326,16 +326,16 @@ replicate [[take 1 (repeat 0)]]
:test (replicate (+3) (+4)) ((+4) : ((+4) : ((+4) : empty)))
# returns an infinite list repeating a finite list
-cycle Z [[rec]]
+cycle z [[rec]]
rec 0 ++ (1 0)
:test (take (+6) (cycle "ab")) ("ababab")
# returns a list with infinite-times previous (or start) value applied to a function
-iterate Z [[[rec]]]
+iterate z [[[rec]]]
rec 0 : (2 1 (1 0))
:test (take (+5) (iterate inc (+0))) (((+0) : ((+1) : ((+2) : ((+3) : ((+4) : empty))))))
:test (take (+2) (iterate dec (+5))) (((+5) : ((+4) : empty)))
-:test (take (+5) (iterate I (+4))) (repeat (+5) (+4))
+:test (take (+5) (iterate i (+4))) (repeat (+5) (+4))
:test (take (+0) (iterate inc (+0))) (empty)
diff --git a/std/Logic.bruijn b/std/Logic.bruijn
index 94e737d..0e7c1ba 100644
--- a/std/Logic.bruijn
+++ b/std/Logic.bruijn
@@ -3,10 +3,10 @@
:import std/Combinator .
# true
-true K
+true k
# false
-false KI
+false ki
# inverts boolean value
not! [0 false true]
diff --git a/std/Pair.bruijn b/std/Pair.bruijn
index b21d193..8dffe7d 100644
--- a/std/Pair.bruijn
+++ b/std/Pair.bruijn
@@ -8,35 +8,40 @@ pair [[[0 2 1]]]
(:) pair
# extracts first expression from pair
-fst [0 K]
+fst [0 k]
^( fst
-# test fst with example pair of [[0]] and [[1]]
:test (^([[0]] : [[1]])) ([[0]])
# extracts second expression from pair
-snd [0 KI]
+snd [0 ki]
~( snd
-# test snd with example pair of [[0]] and [[1]]
:test (~([[0]] : [[1]])) ([[1]])
# applies both elements of a pair to a function
uncurry [[1 ^0 ~0]]
-# test uncurry with example pair of [[0]] and [[1]] and some combinator
-:test (uncurry W ([[0]] : [[1]])) ([[1]])
+:test (uncurry w ([[0]] : [[1]])) ([[1]])
# applies a function to the pair of two values
curry [[[2 (1 : 0)]]]
-# test curry with example pair of [[0]] and [[1]] and fst
:test (curry fst [[0]] [[1]]) ([[0]])
-# swaps the values of a pair
+# zips two pairs (basically rotating the elements)
+zip [[(^1 : ^0) : (~1 : ~0)]]
+
+:test (zip ([[0]] : [[[0]]]) ([[1]] : [[[1]]])) (([[0]] : [[1]]) : ([[[0]]] : [[[1]]]))
+
+# applies pairs of two pairs as arguments to a function
+zip-with [[[(2 ^1 ^0) : (2 ~1 ~0)]]]
+
+:test (zip-with w ([[0]] : [[[0]]]) ([[1]] : [[[1]]])) ([[1]] : [0])
+
+# swaps the elements of a pair
swap [~0 : ^0]
-# test swap with example pair of [[0]] and [[1]]
:test (swap ([[0]] : [[1]])) ([[1]] : [[0]])