diff options
author | Raito Bezarius | 2024-04-18 14:43:52 +0200 |
---|---|---|
committer | Raito Bezarius | 2024-04-18 14:43:52 +0200 |
commit | 0f49a61cc33bddf2cc69bc8915b95c915dc5f987 (patch) | |
tree | 5ed1205b2237827103b3c6db15152e23ec8456fb /AvlVerification.lean | |
parent | 8ed11ddcc8ccee48300ffee8cf68408a711a51ca (diff) |
feat: extract `find`
Signed-off-by: Raito Bezarius <masterancpp@gmail.com>
Diffstat (limited to '')
-rw-r--r-- | AvlVerification.lean | 30 |
1 files changed, 28 insertions, 2 deletions
diff --git a/AvlVerification.lean b/AvlVerification.lean index f9e6830..9380768 100644 --- a/AvlVerification.lean +++ b/AvlVerification.lean @@ -32,6 +32,32 @@ structure AVLTreeSet (T : Type) where def AVLTreeSet.new (T : Type) (OrdInst : Ord T) : Result (AVLTreeSet T) := Result.ok { root := none } +/- [avl_verification::{avl_verification::AVLTreeSet<T>}::find]: loop 0: + Source: 'src/main.rs', lines 30:4-42:5 -/ +divergent def AVLTreeSet.find_loop + (T : Type) (OrdInst : Ord T) (value : T) (current_tree : Option (AVLNode T)) + : + Result Bool + := + match current_tree with + | none => Result.ok false + | some current_node => + do + let ⟨ t, current_tree1, current_tree2 ⟩ := current_node + let o ← OrdInst.cmp t value + match o with + | Ordering.Less => AVLTreeSet.find_loop T OrdInst value current_tree2 + | Ordering.Equal => Result.ok true + | Ordering.Greater => AVLTreeSet.find_loop T OrdInst value current_tree1 + +/- [avl_verification::{avl_verification::AVLTreeSet<T>}::find]: + Source: 'src/main.rs', lines 30:4-30:40 -/ +def AVLTreeSet.find + (T : Type) (OrdInst : Ord T) (self : AVLTreeSet T) (value : T) : + Result Bool + := + AVLTreeSet.find_loop T OrdInst value self.root + /- [avl_verification::{avl_verification::AVLTreeSet<T>}::insert]: loop 0: Source: 'src/main.rs', lines 43:4-61:5 -/ divergent def AVLTreeSet.insert_loop @@ -67,8 +93,8 @@ def AVLTreeSet.insert Result (Bool × (AVLTreeSet T)) := do - let (b, u) ← AVLTreeSet.insert_loop T OrdInst value self.root - Result.ok (b, { root := u }) + let (b, as) ← AVLTreeSet.insert_loop T OrdInst value self.root + Result.ok (b, { root := as }) /- [avl_verification::{(avl_verification::Ord for u32)#1}::cmp]: Source: 'src/main.rs', lines 65:4-65:43 -/ |