summaryrefslogtreecommitdiff
path: root/backends/lean/Base/Diverge
diff options
context:
space:
mode:
authorSon Ho2023-12-07 16:29:18 +0100
committerSon Ho2023-12-07 16:29:18 +0100
commitf7493580421d31b1d3798521b4f9154e69755f89 (patch)
treebbd020f2d69a0c00e92083e040808f4048962765 /backends/lean/Base/Diverge
parentb3b53e369233247d41770432396fbd1932633c0d (diff)
Reorganize a bit
Diffstat (limited to '')
-rw-r--r--backends/lean/Base/Diverge/Elab.lean24
1 files changed, 20 insertions, 4 deletions
diff --git a/backends/lean/Base/Diverge/Elab.lean b/backends/lean/Base/Diverge/Elab.lean
index c6628486..0088fd16 100644
--- a/backends/lean/Base/Diverge/Elab.lean
+++ b/backends/lean/Base/Diverge/Elab.lean
@@ -418,7 +418,7 @@ partial def proveExprIsValid (k_var kk_var : Expr) (e : Expr) : MetaM Expr := do
| .lit _
| .mvar _
| .sort _ => throwError "Unreachable"
- | .lam .. => throwError "Unimplemented"
+ | .lam .. => throwError "Unimplemented" -- TODO
| .forallE .. => throwError "Unreachable" -- Shouldn't get there
| .letE .. => do
-- Telescope all the let-bindings (remark: this also telescopes the lambdas)
@@ -585,6 +585,7 @@ partial def proveExprIsValid (k_var kk_var : Expr) (e : Expr) : MetaM Expr := do
else do
-- Remaining case: normal application.
-- It shouldn't use the continuation.
+ -- TODO: actually, it can
proveNoKExprIsValid k_var e
-- Prove that a match expression is valid.
@@ -1087,17 +1088,33 @@ namespace Tests
. intro i hpos h; simp at h; linarith
. rename_i hd tl ih
intro i hpos h
- -- We can directly use `rw [list_nth]`!
+ -- We can directly use `rw [list_nth]`
rw [list_nth]; simp
split <;> try simp [*]
. tauto
- . -- TODO: we shouldn't have to do that
+ . -- We don't have to do this if we use scalar_tac
have hneq : 0 < i := by cases i <;> rename_i a _ <;> simp_all; cases a <;> simp_all
simp at h
have ⟨ x, ih ⟩ := ih (i - 1) (by linarith) (by linarith)
simp [ih]
tauto
+ -- Return a continuation
+ divergent def list_nth_with_back {a: Type} (ls : List a) (i : Int) :
+ Result (a × (a → Result (List a))) :=
+ match ls with
+ | [] => .fail .panic
+ | x :: ls =>
+ if i = 0 then return (x, (λ ret => return (ret :: ls)))
+ else do
+ let (x, back) ← list_nth_with_back ls (i - 1)
+ return (x,
+ (λ ret => do
+ let ls ← back ret
+ return (x :: ls)))
+
+ #check list_nth_with_back.unfold
+
mutual
divergent def is_even (i : Int) : Result Bool :=
if i = 0 then return true else return (← is_odd (i - 1))
@@ -1121,7 +1138,6 @@ namespace Tests
#check bar.unfold
-- Testing dependent branching and let-bindings
- -- TODO: why the linter warning?
divergent def isNonZero (i : Int) : Result Bool :=
if _h:i = 0 then return false
else