Skip to content

Commit

Permalink
Add tail-recursive version of to_list for computeLib
Browse files Browse the repository at this point in the history
  • Loading branch information
xrchz committed Dec 20, 2024
1 parent 1feeec0 commit 317b751
Showing 1 changed file with 18 additions and 1 deletion.
19 changes: 18 additions & 1 deletion src/num/theories/cv_compute/automation/cv_typeScript.sml
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ Definition from_list_def:
from_list f (x::xs) = Pair (f x) (from_list f xs)
End

Definition to_list_def:
Definition to_list_def[nocompute]:
to_list f (Num n) = [] /\
to_list f (Pair x y) = f x :: to_list f y
End
Expand All @@ -203,6 +203,23 @@ Proof
\\ Induct \\ fs [from_list_def,to_list_def]
QED

Definition to_list_tr_def:
to_list_tr f (Num n) acc = REVERSE acc /\
to_list_tr f (Pair x y) acc = to_list_tr f y (f x :: acc)
End

Theorem to_list_tr_eq_lemma[local]:
!v acc. to_list_tr f v acc = REVERSE acc ++ to_list f v
Proof
Induct \\ rw[to_list_def, to_list_tr_def]
QED

Theorem to_list_tr_eq[compute]:
to_list f v = to_list_tr f v []
Proof
rw[to_list_tr_eq_lemma]
QED

(* used in definitions of to-functions of user-defined datatype *)

Definition cv_has_shape_def:
Expand Down

0 comments on commit 317b751

Please sign in to comment.