lean4-htt/tests/lean/run/unfoldr.lean
2022-03-06 19:28:01 -08:00

48 lines
1.4 KiB
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

notation "#(" a ")" => ⟨a, by decreasing_tactic⟩
def List.unfoldr {α β : Type u} [sz : SizeOf β] (f : (b : β) → Option (α × { b' : β // sizeOf b' < sizeOf b})) (b : β) : List α :=
match f b with
| none => []
| some (a, ⟨b', h⟩) => a :: unfoldr f b'
def tst1 (n : Nat) : List Nat :=
List.unfoldr (b := n) fun
| 0 => none
| b+1 => some (3*n - b*2, #(b))
#eval tst1 10
def tst2 (n : Nat) : List Nat :=
-- Similar example where we provide our custom `SizeOf` instance
List.unfoldr (sz := ⟨fun b => n - b⟩) (b := 0) fun b =>
if h : b < n then
some (b*2, #(b+1))
else
none
#eval tst2 10
-- More general (and less convenient to use) version that can take an arbitrary well-founded relation.
def List.unfoldr' {α β : Type u} [w : WellFoundedRelation β] (f : (b : β) → Option (α × { b' : β // w.rel b' b})) (b : β) : List α :=
match f b with
| none => []
| some (a, ⟨b', h⟩) => a :: unfoldr' f b'
termination_by unfoldr' b => b
-- We need the `master` branch to test the following example
def tst3 (n : Nat) : List Nat :=
List.unfoldr' (b := n) fun
| 0 => none
| b+1 => some (3*n - b*2, #(b))
#eval tst3 10
def tst4 (n : Nat) : List Nat :=
List.unfoldr' (w := invImage (fun b => n - b) inferInstance) (b := 0) fun b =>
if h : b < n then
some (2*b, #(b+1))
else
none
#eval tst4 10