aboutsummaryrefslogtreecommitdiffhomepage
path: root/std/List.bruijn
diff options
context:
space:
mode:
Diffstat (limited to 'std/List.bruijn')
-rw-r--r--std/List.bruijn11
1 files changed, 7 insertions, 4 deletions
diff --git a/std/List.bruijn b/std/List.bruijn
index 799e966..d8d7dc9 100644
--- a/std/List.bruijn
+++ b/std/List.bruijn
@@ -89,11 +89,11 @@ index-unary [[P.fst (0 P.snd 1)]] ⧗ (List a) → Unary → a
# returns the element at index in list
index z [[[rec]]] ⧗ (List a) → Number → a
- rec 0 [[[case-index]]] case-end
- case-index =?4 2 (5 --4 1)
+ rec 1 [[[case-index]]] case-end
+ case-index =?3 2 (5 1 --3)
case-end empty
-…!!… \index
+…!!… index
:test (((+1) : ((+2) : {}(+3))) !! (+0)) ((+1))
:test (((+1) : ((+2) : {}(+3))) !! (+2)) ((+3))
@@ -519,12 +519,15 @@ iterate z [[[rec]]] ⧗ (a → a) → a → (List a)
:test (take (+5) (iterate i (+4))) (take (+5) (repeat (+4)))
:test (take (+0) (iterate ++‣ (+0))) (empty)
+# TODO: performance
+nth-iterate index ∘∘ iterate
+
# enumerate list
enumerate zip (iterate ++‣ (+0)) ⧗ (List a) → (List (Pair Number a))
:test (enumerate "abc") (((+0) : 'a') : (((+1) : 'b') : {}((+2) : 'c')))
-# calculates all fixed points of given function as a list
+# calculates all fixed points of given functions as a list
y* [[[0 1] <$> 0] xs] ⧗ (List a) → (List b)
xs [[1 <! ([[1 2 0]] <$> 0)]] <$> 0