author | wenzelm |
Fri, 13 Apr 2012 14:00:26 +0200 | |
changeset 47455 | 26315a545e26 |
parent 47450 | 2ada2be850cb |
child 48621 | 877df57629e3 |
permissions | -rw-r--r-- |
47455 | 1 |
(* Title: HOL/Library/RBT_Impl.thy |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
2 |
Author: Markus Reiter, TU Muenchen |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
3 |
Author: Alexander Krauss, TU Muenchen |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
4 |
*) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
5 |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
6 |
header {* Implementation of Red-Black Trees *} |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
7 |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
8 |
theory RBT_Impl |
45990
b7b905b23b2a
incorporated More_Set and More_List into the Main body -- to be consolidated later
haftmann
parents:
41959
diff
changeset
|
9 |
imports Main |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
10 |
begin |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
11 |
|
36147
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
12 |
text {* |
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
13 |
For applications, you should use theory @{text RBT} which defines |
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
14 |
an abstract type of red-black tree obeying the invariant. |
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
15 |
*} |
b43b22f63665
theory RBT with abstract type of red-black trees backed by implementation RBT_Impl
haftmann
parents:
35618
diff
changeset
|
16 |
|
35550 | 17 |
subsection {* Datatype of RB trees *} |
18 |
||
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
19 |
datatype color = R | B |
35534 | 20 |
datatype ('a, 'b) rbt = Empty | Branch color "('a, 'b) rbt" 'a 'b "('a, 'b) rbt" |
21 |
||
22 |
lemma rbt_cases: |
|
23 |
obtains (Empty) "t = Empty" |
|
24 |
| (Red) l k v r where "t = Branch R l k v r" |
|
25 |
| (Black) l k v r where "t = Branch B l k v r" |
|
26 |
proof (cases t) |
|
27 |
case Empty with that show thesis by blast |
|
28 |
next |
|
29 |
case (Branch c) with that show thesis by (cases c) blast+ |
|
30 |
qed |
|
31 |
||
35550 | 32 |
subsection {* Tree properties *} |
35534 | 33 |
|
35550 | 34 |
subsubsection {* Content of a tree *} |
35 |
||
36 |
primrec entries :: "('a, 'b) rbt \<Rightarrow> ('a \<times> 'b) list" |
|
35534 | 37 |
where |
38 |
"entries Empty = []" |
|
39 |
| "entries (Branch _ l k v r) = entries l @ (k,v) # entries r" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
40 |
|
35550 | 41 |
abbreviation (input) entry_in_tree :: "'a \<Rightarrow> 'b \<Rightarrow> ('a, 'b) rbt \<Rightarrow> bool" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
42 |
where |
35550 | 43 |
"entry_in_tree k v t \<equiv> (k, v) \<in> set (entries t)" |
44 |
||
45 |
definition keys :: "('a, 'b) rbt \<Rightarrow> 'a list" where |
|
46 |
"keys t = map fst (entries t)" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
47 |
|
35550 | 48 |
lemma keys_simps [simp, code]: |
49 |
"keys Empty = []" |
|
50 |
"keys (Branch c l k v r) = keys l @ k # keys r" |
|
51 |
by (simp_all add: keys_def) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
52 |
|
35534 | 53 |
lemma entry_in_tree_keys: |
35550 | 54 |
assumes "(k, v) \<in> set (entries t)" |
55 |
shows "k \<in> set (keys t)" |
|
56 |
proof - |
|
57 |
from assms have "fst (k, v) \<in> fst ` set (entries t)" by (rule imageI) |
|
58 |
then show ?thesis by (simp add: keys_def) |
|
59 |
qed |
|
60 |
||
35602 | 61 |
lemma keys_entries: |
62 |
"k \<in> set (keys t) \<longleftrightarrow> (\<exists>v. (k, v) \<in> set (entries t))" |
|
63 |
by (auto intro: entry_in_tree_keys) (auto simp add: keys_def) |
|
64 |
||
35550 | 65 |
|
66 |
subsubsection {* Search tree properties *} |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
67 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
68 |
context ord begin |
35534 | 69 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
70 |
definition rbt_less :: "'a \<Rightarrow> ('a, 'b) rbt \<Rightarrow> bool" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
71 |
where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
72 |
rbt_less_prop: "rbt_less k t \<longleftrightarrow> (\<forall>x\<in>set (keys t). x < k)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
73 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
74 |
abbreviation rbt_less_symbol (infix "|\<guillemotleft>" 50) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
75 |
where "t |\<guillemotleft> x \<equiv> rbt_less x t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
76 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
77 |
definition rbt_greater :: "'a \<Rightarrow> ('a, 'b) rbt \<Rightarrow> bool" (infix "\<guillemotleft>|" 50) |
35534 | 78 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
79 |
rbt_greater_prop: "rbt_greater k t = (\<forall>x\<in>set (keys t). k < x)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
80 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
81 |
lemma rbt_less_simps [simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
82 |
"Empty |\<guillemotleft> k = True" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
83 |
"Branch c lt kt v rt |\<guillemotleft> k \<longleftrightarrow> kt < k \<and> lt |\<guillemotleft> k \<and> rt |\<guillemotleft> k" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
84 |
by (auto simp add: rbt_less_prop) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
85 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
86 |
lemma rbt_greater_simps [simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
87 |
"k \<guillemotleft>| Empty = True" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
88 |
"k \<guillemotleft>| (Branch c lt kt v rt) \<longleftrightarrow> k < kt \<and> k \<guillemotleft>| lt \<and> k \<guillemotleft>| rt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
89 |
by (auto simp add: rbt_greater_prop) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
90 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
91 |
lemmas rbt_ord_props = rbt_less_prop rbt_greater_prop |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
92 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
93 |
lemmas rbt_greater_nit = rbt_greater_prop entry_in_tree_keys |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
94 |
lemmas rbt_less_nit = rbt_less_prop entry_in_tree_keys |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
95 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
96 |
lemma (in order) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
97 |
shows rbt_less_eq_trans: "l |\<guillemotleft> u \<Longrightarrow> u \<le> v \<Longrightarrow> l |\<guillemotleft> v" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
98 |
and rbt_less_trans: "t |\<guillemotleft> x \<Longrightarrow> x < y \<Longrightarrow> t |\<guillemotleft> y" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
99 |
and rbt_greater_eq_trans: "u \<le> v \<Longrightarrow> v \<guillemotleft>| r \<Longrightarrow> u \<guillemotleft>| r" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
100 |
and rbt_greater_trans: "x < y \<Longrightarrow> y \<guillemotleft>| t \<Longrightarrow> x \<guillemotleft>| t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
101 |
by (auto simp: rbt_ord_props) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
102 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
103 |
primrec rbt_sorted :: "('a, 'b) rbt \<Rightarrow> bool" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
104 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
105 |
"rbt_sorted Empty = True" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
106 |
| "rbt_sorted (Branch c l k v r) = (l |\<guillemotleft> k \<and> k \<guillemotleft>| r \<and> rbt_sorted l \<and> rbt_sorted r)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
107 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
108 |
end |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
109 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
110 |
context linorder begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
111 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
112 |
lemma rbt_sorted_entries: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
113 |
"rbt_sorted t \<Longrightarrow> List.sorted (List.map fst (entries t))" |
35550 | 114 |
by (induct t) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
115 |
(force simp: sorted_append sorted_Cons rbt_ord_props |
35550 | 116 |
dest!: entry_in_tree_keys)+ |
117 |
||
118 |
lemma distinct_entries: |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
119 |
"rbt_sorted t \<Longrightarrow> distinct (List.map fst (entries t))" |
35550 | 120 |
by (induct t) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
121 |
(force simp: sorted_append sorted_Cons rbt_ord_props |
35550 | 122 |
dest!: entry_in_tree_keys)+ |
123 |
||
124 |
subsubsection {* Tree lookup *} |
|
125 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
126 |
primrec (in ord) rbt_lookup :: "('a, 'b) rbt \<Rightarrow> 'a \<rightharpoonup> 'b" |
35534 | 127 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
128 |
"rbt_lookup Empty k = None" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
129 |
| "rbt_lookup (Branch _ l x y r) k = |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
130 |
(if k < x then rbt_lookup l k else if x < k then rbt_lookup r k else Some y)" |
35534 | 131 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
132 |
lemma rbt_lookup_keys: "rbt_sorted t \<Longrightarrow> dom (rbt_lookup t) = set (keys t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
133 |
by (induct t) (auto simp: dom_def rbt_greater_prop rbt_less_prop) |
35550 | 134 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
135 |
lemma dom_rbt_lookup_Branch: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
136 |
"rbt_sorted (Branch c t1 k v t2) \<Longrightarrow> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
137 |
dom (rbt_lookup (Branch c t1 k v t2)) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
138 |
= Set.insert k (dom (rbt_lookup t1) \<union> dom (rbt_lookup t2))" |
35550 | 139 |
proof - |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
140 |
assume "rbt_sorted (Branch c t1 k v t2)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
141 |
moreover from this have "rbt_sorted t1" "rbt_sorted t2" by simp_all |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
142 |
ultimately show ?thesis by (simp add: rbt_lookup_keys) |
35550 | 143 |
qed |
144 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
145 |
lemma finite_dom_rbt_lookup [simp, intro!]: "finite (dom (rbt_lookup t))" |
35550 | 146 |
proof (induct t) |
147 |
case Empty then show ?case by simp |
|
148 |
next |
|
149 |
case (Branch color t1 a b t2) |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
150 |
let ?A = "Set.insert a (dom (rbt_lookup t1) \<union> dom (rbt_lookup t2))" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
151 |
have "dom (rbt_lookup (Branch color t1 a b t2)) \<subseteq> ?A" by (auto split: split_if_asm) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
152 |
moreover from Branch have "finite (insert a (dom (rbt_lookup t1) \<union> dom (rbt_lookup t2)))" by simp |
35550 | 153 |
ultimately show ?case by (rule finite_subset) |
154 |
qed |
|
155 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
156 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
157 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
158 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
159 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
160 |
lemma rbt_lookup_rbt_less[simp]: "t |\<guillemotleft> k \<Longrightarrow> rbt_lookup t k = None" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
161 |
by (induct t) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
162 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
163 |
lemma rbt_lookup_rbt_greater[simp]: "k \<guillemotleft>| t \<Longrightarrow> rbt_lookup t k = None" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
164 |
by (induct t) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
165 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
166 |
lemma rbt_lookup_Empty: "rbt_lookup Empty = empty" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
167 |
by (rule ext) simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
168 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
169 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
170 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
171 |
context linorder begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
172 |
|
35618 | 173 |
lemma map_of_entries: |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
174 |
"rbt_sorted t \<Longrightarrow> map_of (entries t) = rbt_lookup t" |
35550 | 175 |
proof (induct t) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
176 |
case Empty thus ?case by (simp add: rbt_lookup_Empty) |
35550 | 177 |
next |
178 |
case (Branch c t1 k v t2) |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
179 |
have "rbt_lookup (Branch c t1 k v t2) = rbt_lookup t2 ++ [k\<mapsto>v] ++ rbt_lookup t1" |
35550 | 180 |
proof (rule ext) |
181 |
fix x |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
182 |
from Branch have RBT_SORTED: "rbt_sorted (Branch c t1 k v t2)" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
183 |
let ?thesis = "rbt_lookup (Branch c t1 k v t2) x = (rbt_lookup t2 ++ [k \<mapsto> v] ++ rbt_lookup t1) x" |
35550 | 184 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
185 |
have DOM_T1: "!!k'. k'\<in>dom (rbt_lookup t1) \<Longrightarrow> k>k'" |
35550 | 186 |
proof - |
187 |
fix k' |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
188 |
from RBT_SORTED have "t1 |\<guillemotleft> k" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
189 |
with rbt_less_prop have "\<forall>k'\<in>set (keys t1). k>k'" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
190 |
moreover assume "k'\<in>dom (rbt_lookup t1)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
191 |
ultimately show "k>k'" using rbt_lookup_keys RBT_SORTED by auto |
35550 | 192 |
qed |
193 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
194 |
have DOM_T2: "!!k'. k'\<in>dom (rbt_lookup t2) \<Longrightarrow> k<k'" |
35550 | 195 |
proof - |
196 |
fix k' |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
197 |
from RBT_SORTED have "k \<guillemotleft>| t2" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
198 |
with rbt_greater_prop have "\<forall>k'\<in>set (keys t2). k<k'" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
199 |
moreover assume "k'\<in>dom (rbt_lookup t2)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
200 |
ultimately show "k<k'" using rbt_lookup_keys RBT_SORTED by auto |
35550 | 201 |
qed |
202 |
||
203 |
{ |
|
204 |
assume C: "x<k" |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
205 |
hence "rbt_lookup (Branch c t1 k v t2) x = rbt_lookup t1 x" by simp |
35550 | 206 |
moreover from C have "x\<notin>dom [k\<mapsto>v]" by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
207 |
moreover have "x \<notin> dom (rbt_lookup t2)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
208 |
proof |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
209 |
assume "x \<in> dom (rbt_lookup t2)" |
35550 | 210 |
with DOM_T2 have "k<x" by blast |
211 |
with C show False by simp |
|
212 |
qed |
|
213 |
ultimately have ?thesis by (simp add: map_add_upd_left map_add_dom_app_simps) |
|
214 |
} moreover { |
|
215 |
assume [simp]: "x=k" |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
216 |
hence "rbt_lookup (Branch c t1 k v t2) x = [k \<mapsto> v] x" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
217 |
moreover have "x \<notin> dom (rbt_lookup t1)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
218 |
proof |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
219 |
assume "x \<in> dom (rbt_lookup t1)" |
35550 | 220 |
with DOM_T1 have "k>x" by blast |
221 |
thus False by simp |
|
222 |
qed |
|
223 |
ultimately have ?thesis by (simp add: map_add_upd_left map_add_dom_app_simps) |
|
224 |
} moreover { |
|
225 |
assume C: "x>k" |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
226 |
hence "rbt_lookup (Branch c t1 k v t2) x = rbt_lookup t2 x" by (simp add: less_not_sym[of k x]) |
35550 | 227 |
moreover from C have "x\<notin>dom [k\<mapsto>v]" by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
228 |
moreover have "x\<notin>dom (rbt_lookup t1)" proof |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
229 |
assume "x\<in>dom (rbt_lookup t1)" |
35550 | 230 |
with DOM_T1 have "k>x" by simp |
231 |
with C show False by simp |
|
232 |
qed |
|
233 |
ultimately have ?thesis by (simp add: map_add_upd_left map_add_dom_app_simps) |
|
234 |
} ultimately show ?thesis using less_linear by blast |
|
235 |
qed |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
236 |
also from Branch |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
237 |
have "rbt_lookup t2 ++ [k \<mapsto> v] ++ rbt_lookup t1 = map_of (entries (Branch c t1 k v t2))" by simp |
35618 | 238 |
finally show ?case by simp |
35550 | 239 |
qed |
240 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
241 |
lemma rbt_lookup_in_tree: "rbt_sorted t \<Longrightarrow> rbt_lookup t k = Some v \<longleftrightarrow> (k, v) \<in> set (entries t)" |
35618 | 242 |
by (simp add: map_of_entries [symmetric] distinct_entries) |
35602 | 243 |
|
244 |
lemma set_entries_inject: |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
245 |
assumes rbt_sorted: "rbt_sorted t1" "rbt_sorted t2" |
35602 | 246 |
shows "set (entries t1) = set (entries t2) \<longleftrightarrow> entries t1 = entries t2" |
247 |
proof - |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
248 |
from rbt_sorted have "distinct (map fst (entries t1))" |
35602 | 249 |
"distinct (map fst (entries t2))" |
250 |
by (auto intro: distinct_entries) |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
251 |
with rbt_sorted show ?thesis |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
252 |
by (auto intro: map_sorted_distinct_set_unique rbt_sorted_entries simp add: distinct_map) |
35602 | 253 |
qed |
35550 | 254 |
|
255 |
lemma entries_eqI: |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
256 |
assumes rbt_sorted: "rbt_sorted t1" "rbt_sorted t2" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
257 |
assumes rbt_lookup: "rbt_lookup t1 = rbt_lookup t2" |
35602 | 258 |
shows "entries t1 = entries t2" |
35550 | 259 |
proof - |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
260 |
from rbt_sorted rbt_lookup have "map_of (entries t1) = map_of (entries t2)" |
35618 | 261 |
by (simp add: map_of_entries) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
262 |
with rbt_sorted have "set (entries t1) = set (entries t2)" |
35602 | 263 |
by (simp add: map_of_inject_set distinct_entries) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
264 |
with rbt_sorted show ?thesis by (simp add: set_entries_inject) |
35602 | 265 |
qed |
35550 | 266 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
267 |
lemma entries_rbt_lookup: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
268 |
assumes "rbt_sorted t1" "rbt_sorted t2" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
269 |
shows "entries t1 = entries t2 \<longleftrightarrow> rbt_lookup t1 = rbt_lookup t2" |
35618 | 270 |
using assms by (auto intro: entries_eqI simp add: map_of_entries [symmetric]) |
35602 | 271 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
272 |
lemma rbt_lookup_from_in_tree: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
273 |
assumes "rbt_sorted t1" "rbt_sorted t2" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
274 |
and "\<And>v. (k, v) \<in> set (entries t1) \<longleftrightarrow> (k, v) \<in> set (entries t2)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
275 |
shows "rbt_lookup t1 k = rbt_lookup t2 k" |
35602 | 276 |
proof - |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
277 |
from assms have "k \<in> dom (rbt_lookup t1) \<longleftrightarrow> k \<in> dom (rbt_lookup t2)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
278 |
by (simp add: keys_entries rbt_lookup_keys) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
279 |
with assms show ?thesis by (auto simp add: rbt_lookup_in_tree [symmetric]) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
280 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
281 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
282 |
end |
35550 | 283 |
|
284 |
subsubsection {* Red-black properties *} |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
285 |
|
35534 | 286 |
primrec color_of :: "('a, 'b) rbt \<Rightarrow> color" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
287 |
where |
35534 | 288 |
"color_of Empty = B" |
289 |
| "color_of (Branch c _ _ _ _) = c" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
290 |
|
35534 | 291 |
primrec bheight :: "('a,'b) rbt \<Rightarrow> nat" |
292 |
where |
|
293 |
"bheight Empty = 0" |
|
294 |
| "bheight (Branch c lt k v rt) = (if c = B then Suc (bheight lt) else bheight lt)" |
|
295 |
||
296 |
primrec inv1 :: "('a, 'b) rbt \<Rightarrow> bool" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
297 |
where |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
298 |
"inv1 Empty = True" |
35534 | 299 |
| "inv1 (Branch c lt k v rt) \<longleftrightarrow> inv1 lt \<and> inv1 rt \<and> (c = B \<or> color_of lt = B \<and> color_of rt = B)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
300 |
|
35534 | 301 |
primrec inv1l :: "('a, 'b) rbt \<Rightarrow> bool" -- {* Weaker version *} |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
302 |
where |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
303 |
"inv1l Empty = True" |
35534 | 304 |
| "inv1l (Branch c l k v r) = (inv1 l \<and> inv1 r)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
305 |
lemma [simp]: "inv1 t \<Longrightarrow> inv1l t" by (cases t) simp+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
306 |
|
35534 | 307 |
primrec inv2 :: "('a, 'b) rbt \<Rightarrow> bool" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
308 |
where |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
309 |
"inv2 Empty = True" |
35534 | 310 |
| "inv2 (Branch c lt k v rt) = (inv2 lt \<and> inv2 rt \<and> bheight lt = bheight rt)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
311 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
312 |
context ord begin |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
313 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
314 |
definition is_rbt :: "('a, 'b) rbt \<Rightarrow> bool" where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
315 |
"is_rbt t \<longleftrightarrow> inv1 t \<and> inv2 t \<and> color_of t = B \<and> rbt_sorted t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
316 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
317 |
lemma is_rbt_rbt_sorted [simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
318 |
"is_rbt t \<Longrightarrow> rbt_sorted t" by (simp add: is_rbt_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
319 |
|
35534 | 320 |
theorem Empty_is_rbt [simp]: |
321 |
"is_rbt Empty" by (simp add: is_rbt_def) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
322 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
323 |
end |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
324 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
325 |
subsection {* Insertion *} |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
326 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
327 |
fun (* slow, due to massive case splitting *) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
328 |
balance :: "('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
329 |
where |
35534 | 330 |
"balance (Branch R a w x b) s t (Branch R c y z d) = Branch R (Branch B a w x b) s t (Branch B c y z d)" | |
331 |
"balance (Branch R (Branch R a w x b) s t c) y z d = Branch R (Branch B a w x b) s t (Branch B c y z d)" | |
|
332 |
"balance (Branch R a w x (Branch R b s t c)) y z d = Branch R (Branch B a w x b) s t (Branch B c y z d)" | |
|
333 |
"balance a w x (Branch R b s t (Branch R c y z d)) = Branch R (Branch B a w x b) s t (Branch B c y z d)" | |
|
334 |
"balance a w x (Branch R (Branch R b s t c) y z d) = Branch R (Branch B a w x b) s t (Branch B c y z d)" | |
|
335 |
"balance a s t b = Branch B a s t b" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
336 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
337 |
lemma balance_inv1: "\<lbrakk>inv1l l; inv1l r\<rbrakk> \<Longrightarrow> inv1 (balance l k v r)" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
338 |
by (induct l k v r rule: balance.induct) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
339 |
|
35534 | 340 |
lemma balance_bheight: "bheight l = bheight r \<Longrightarrow> bheight (balance l k v r) = Suc (bheight l)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
341 |
by (induct l k v r rule: balance.induct) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
342 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
343 |
lemma balance_inv2: |
35534 | 344 |
assumes "inv2 l" "inv2 r" "bheight l = bheight r" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
345 |
shows "inv2 (balance l k v r)" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
346 |
using assms |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
347 |
by (induct l k v r rule: balance.induct) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
348 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
349 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
350 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
351 |
lemma balance_rbt_greater[simp]: "(v \<guillemotleft>| balance a k x b) = (v \<guillemotleft>| a \<and> v \<guillemotleft>| b \<and> v < k)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
352 |
by (induct a k x b rule: balance.induct) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
353 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
354 |
lemma balance_rbt_less[simp]: "(balance a k x b |\<guillemotleft> v) = (a |\<guillemotleft> v \<and> b |\<guillemotleft> v \<and> k < v)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
355 |
by (induct a k x b rule: balance.induct) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
356 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
357 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
358 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
359 |
lemma (in linorder) balance_rbt_sorted: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
360 |
fixes k :: "'a" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
361 |
assumes "rbt_sorted l" "rbt_sorted r" "l |\<guillemotleft> k" "k \<guillemotleft>| r" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
362 |
shows "rbt_sorted (balance l k v r)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
363 |
using assms proof (induct l k v r rule: balance.induct) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
364 |
case ("2_2" a x w b y t c z s va vb vd vc) |
35534 | 365 |
hence "y < z \<and> z \<guillemotleft>| Branch B va vb vd vc" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
366 |
by (auto simp add: rbt_ord_props) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
367 |
hence "y \<guillemotleft>| (Branch B va vb vd vc)" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
368 |
with "2_2" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
369 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
370 |
case ("3_2" va vb vd vc x w b y s c z) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
371 |
from "3_2" have "x < y \<and> Branch B va vb vd vc |\<guillemotleft> x" |
35534 | 372 |
by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
373 |
hence "Branch B va vb vd vc |\<guillemotleft> y" by (blast dest: rbt_less_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
374 |
with "3_2" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
375 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
376 |
case ("3_3" x w b y s c z t va vb vd vc) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
377 |
from "3_3" have "y < z \<and> z \<guillemotleft>| Branch B va vb vd vc" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
378 |
hence "y \<guillemotleft>| Branch B va vb vd vc" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
379 |
with "3_3" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
380 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
381 |
case ("3_4" vd ve vg vf x w b y s c z t va vb vii vc) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
382 |
hence "x < y \<and> Branch B vd ve vg vf |\<guillemotleft> x" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
383 |
hence 1: "Branch B vd ve vg vf |\<guillemotleft> y" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
384 |
from "3_4" have "y < z \<and> z \<guillemotleft>| Branch B va vb vii vc" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
385 |
hence "y \<guillemotleft>| Branch B va vb vii vc" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
386 |
with 1 "3_4" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
387 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
388 |
case ("4_2" va vb vd vc x w b y s c z t dd) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
389 |
hence "x < y \<and> Branch B va vb vd vc |\<guillemotleft> x" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
390 |
hence "Branch B va vb vd vc |\<guillemotleft> y" by (blast dest: rbt_less_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
391 |
with "4_2" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
392 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
393 |
case ("5_2" x w b y s c z t va vb vd vc) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
394 |
hence "y < z \<and> z \<guillemotleft>| Branch B va vb vd vc" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
395 |
hence "y \<guillemotleft>| Branch B va vb vd vc" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
396 |
with "5_2" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
397 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
398 |
case ("5_3" va vb vd vc x w b y s c z t) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
399 |
hence "x < y \<and> Branch B va vb vd vc |\<guillemotleft> x" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
400 |
hence "Branch B va vb vd vc |\<guillemotleft> y" by (blast dest: rbt_less_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
401 |
with "5_3" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
402 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
403 |
case ("5_4" va vb vg vc x w b y s c z t vd ve vii vf) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
404 |
hence "x < y \<and> Branch B va vb vg vc |\<guillemotleft> x" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
405 |
hence 1: "Branch B va vb vg vc |\<guillemotleft> y" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
406 |
from "5_4" have "y < z \<and> z \<guillemotleft>| Branch B vd ve vii vf" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
407 |
hence "y \<guillemotleft>| Branch B vd ve vii vf" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
408 |
with 1 "5_4" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
409 |
qed simp+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
410 |
|
35550 | 411 |
lemma entries_balance [simp]: |
412 |
"entries (balance l k v r) = entries l @ (k, v) # entries r" |
|
413 |
by (induct l k v r rule: balance.induct) auto |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
414 |
|
35550 | 415 |
lemma keys_balance [simp]: |
416 |
"keys (balance l k v r) = keys l @ k # keys r" |
|
417 |
by (simp add: keys_def) |
|
418 |
||
419 |
lemma balance_in_tree: |
|
420 |
"entry_in_tree k x (balance l v y r) \<longleftrightarrow> entry_in_tree k x l \<or> k = v \<and> x = y \<or> entry_in_tree k x r" |
|
421 |
by (auto simp add: keys_def) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
422 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
423 |
lemma (in linorder) rbt_lookup_balance[simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
424 |
fixes k :: "'a" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
425 |
assumes "rbt_sorted l" "rbt_sorted r" "l |\<guillemotleft> k" "k \<guillemotleft>| r" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
426 |
shows "rbt_lookup (balance l k v r) x = rbt_lookup (Branch B l k v r) x" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
427 |
by (rule rbt_lookup_from_in_tree) (auto simp:assms balance_in_tree balance_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
428 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
429 |
primrec paint :: "color \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
430 |
where |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
431 |
"paint c Empty = Empty" |
35534 | 432 |
| "paint c (Branch _ l k v r) = Branch c l k v r" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
433 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
434 |
lemma paint_inv1l[simp]: "inv1l t \<Longrightarrow> inv1l (paint c t)" by (cases t) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
435 |
lemma paint_inv1[simp]: "inv1l t \<Longrightarrow> inv1 (paint B t)" by (cases t) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
436 |
lemma paint_inv2[simp]: "inv2 t \<Longrightarrow> inv2 (paint c t)" by (cases t) auto |
35534 | 437 |
lemma paint_color_of[simp]: "color_of (paint B t) = B" by (cases t) auto |
35550 | 438 |
lemma paint_in_tree[simp]: "entry_in_tree k x (paint c t) = entry_in_tree k x t" by (cases t) auto |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
439 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
440 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
441 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
442 |
lemma paint_rbt_sorted[simp]: "rbt_sorted t \<Longrightarrow> rbt_sorted (paint c t)" by (cases t) auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
443 |
lemma paint_rbt_lookup[simp]: "rbt_lookup (paint c t) = rbt_lookup t" by (rule ext) (cases t, auto) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
444 |
lemma paint_rbt_greater[simp]: "(v \<guillemotleft>| paint c t) = (v \<guillemotleft>| t)" by (cases t) auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
445 |
lemma paint_rbt_less[simp]: "(paint c t |\<guillemotleft> v) = (t |\<guillemotleft> v)" by (cases t) auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
446 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
447 |
fun |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
448 |
rbt_ins :: "('a \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
449 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
450 |
"rbt_ins f k v Empty = Branch R Empty k v Empty" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
451 |
"rbt_ins f k v (Branch B l x y r) = (if k < x then balance (rbt_ins f k v l) x y r |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
452 |
else if k > x then balance l x y (rbt_ins f k v r) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
453 |
else Branch B l x (f k y v) r)" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
454 |
"rbt_ins f k v (Branch R l x y r) = (if k < x then Branch R (rbt_ins f k v l) x y r |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
455 |
else if k > x then Branch R l x y (rbt_ins f k v r) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
456 |
else Branch R l x (f k y v) r)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
457 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
458 |
lemma ins_inv1_inv2: |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
459 |
assumes "inv1 t" "inv2 t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
460 |
shows "inv2 (rbt_ins f k x t)" "bheight (rbt_ins f k x t) = bheight t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
461 |
"color_of t = B \<Longrightarrow> inv1 (rbt_ins f k x t)" "inv1l (rbt_ins f k x t)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
462 |
using assms |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
463 |
by (induct f k x t rule: rbt_ins.induct) (auto simp: balance_inv1 balance_inv2 balance_bheight) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
464 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
465 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
466 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
467 |
context linorder begin |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
468 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
469 |
lemma ins_rbt_greater[simp]: "(v \<guillemotleft>| rbt_ins f (k :: 'a) x t) = (v \<guillemotleft>| t \<and> k > v)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
470 |
by (induct f k x t rule: rbt_ins.induct) auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
471 |
lemma ins_rbt_less[simp]: "(rbt_ins f k x t |\<guillemotleft> v) = (t |\<guillemotleft> v \<and> k < v)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
472 |
by (induct f k x t rule: rbt_ins.induct) auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
473 |
lemma ins_rbt_sorted[simp]: "rbt_sorted t \<Longrightarrow> rbt_sorted (rbt_ins f k x t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
474 |
by (induct f k x t rule: rbt_ins.induct) (auto simp: balance_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
475 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
476 |
lemma keys_ins: "set (keys (rbt_ins f k v t)) = { k } \<union> set (keys t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
477 |
by (induct f k v t rule: rbt_ins.induct) auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
478 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
479 |
lemma rbt_lookup_ins: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
480 |
fixes k :: "'a" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
481 |
assumes "rbt_sorted t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
482 |
shows "rbt_lookup (rbt_ins f k v t) x = ((rbt_lookup t)(k |-> case rbt_lookup t k of None \<Rightarrow> v |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
483 |
| Some w \<Rightarrow> f k w v)) x" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
484 |
using assms by (induct f k v t rule: rbt_ins.induct) auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
485 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
486 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
487 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
488 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
489 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
490 |
definition rbt_insert_with_key :: "('a \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
491 |
where "rbt_insert_with_key f k v t = paint B (rbt_ins f k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
492 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
493 |
definition rbt_insertw_def: "rbt_insert_with f = rbt_insert_with_key (\<lambda>_. f)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
494 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
495 |
definition rbt_insert :: "'a \<Rightarrow> 'b \<Rightarrow> ('a, 'b) rbt \<Rightarrow> ('a, 'b) rbt" where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
496 |
"rbt_insert = rbt_insert_with_key (\<lambda>_ _ nv. nv)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
497 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
498 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
499 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
500 |
context linorder begin |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
501 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
502 |
lemma rbt_insertwk_rbt_sorted: "rbt_sorted t \<Longrightarrow> rbt_sorted (rbt_insert_with_key f (k :: 'a) x t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
503 |
by (auto simp: rbt_insert_with_key_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
504 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
505 |
theorem rbt_insertwk_is_rbt: |
35534 | 506 |
assumes inv: "is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
507 |
shows "is_rbt (rbt_insert_with_key f k x t)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
508 |
using assms |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
509 |
unfolding rbt_insert_with_key_def is_rbt_def |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
510 |
by (auto simp: ins_inv1_inv2) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
511 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
512 |
lemma rbt_lookup_rbt_insertwk: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
513 |
assumes "rbt_sorted t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
514 |
shows "rbt_lookup (rbt_insert_with_key f k v t) x = ((rbt_lookup t)(k |-> case rbt_lookup t k of None \<Rightarrow> v |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
515 |
| Some w \<Rightarrow> f k w v)) x" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
516 |
unfolding rbt_insert_with_key_def using assms |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
517 |
by (simp add:rbt_lookup_ins) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
518 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
519 |
lemma rbt_insertw_rbt_sorted: "rbt_sorted t \<Longrightarrow> rbt_sorted (rbt_insert_with f k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
520 |
by (simp add: rbt_insertwk_rbt_sorted rbt_insertw_def) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
521 |
theorem rbt_insertw_is_rbt: "is_rbt t \<Longrightarrow> is_rbt (rbt_insert_with f k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
522 |
by (simp add: rbt_insertwk_is_rbt rbt_insertw_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
523 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
524 |
lemma rbt_lookup_rbt_insertw: |
35534 | 525 |
assumes "is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
526 |
shows "rbt_lookup (rbt_insert_with f k v t) = (rbt_lookup t)(k \<mapsto> (if k:dom (rbt_lookup t) then f (the (rbt_lookup t k)) v else v))" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
527 |
using assms |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
528 |
unfolding rbt_insertw_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
529 |
by (rule_tac ext) (cases "rbt_lookup t k", auto simp:rbt_lookup_rbt_insertwk dom_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
530 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
531 |
lemma rbt_insert_rbt_sorted: "rbt_sorted t \<Longrightarrow> rbt_sorted (rbt_insert k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
532 |
by (simp add: rbt_insertwk_rbt_sorted rbt_insert_def) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
533 |
theorem rbt_insert_is_rbt [simp]: "is_rbt t \<Longrightarrow> is_rbt (rbt_insert k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
534 |
by (simp add: rbt_insertwk_is_rbt rbt_insert_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
535 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
536 |
lemma rbt_lookup_rbt_insert: |
35534 | 537 |
assumes "is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
538 |
shows "rbt_lookup (rbt_insert k v t) = (rbt_lookup t)(k\<mapsto>v)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
539 |
unfolding rbt_insert_def |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
540 |
using assms |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
541 |
by (rule_tac ext) (simp add: rbt_lookup_rbt_insertwk split:option.split) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
542 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
543 |
end |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
544 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
545 |
subsection {* Deletion *} |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
546 |
|
35534 | 547 |
lemma bheight_paintR'[simp]: "color_of t = B \<Longrightarrow> bheight (paint R t) = bheight t - 1" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
548 |
by (cases t rule: rbt_cases) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
549 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
550 |
fun |
35550 | 551 |
balance_left :: "('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
552 |
where |
35550 | 553 |
"balance_left (Branch R a k x b) s y c = Branch R (Branch B a k x b) s y c" | |
554 |
"balance_left bl k x (Branch B a s y b) = balance bl k x (Branch R a s y b)" | |
|
555 |
"balance_left bl k x (Branch R (Branch B a s y b) t z c) = Branch R (Branch B bl k x a) s y (balance b t z (paint R c))" | |
|
556 |
"balance_left t k x s = Empty" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
557 |
|
35550 | 558 |
lemma balance_left_inv2_with_inv1: |
35534 | 559 |
assumes "inv2 lt" "inv2 rt" "bheight lt + 1 = bheight rt" "inv1 rt" |
35550 | 560 |
shows "bheight (balance_left lt k v rt) = bheight lt + 1" |
561 |
and "inv2 (balance_left lt k v rt)" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
562 |
using assms |
35550 | 563 |
by (induct lt k v rt rule: balance_left.induct) (auto simp: balance_inv2 balance_bheight) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
564 |
|
35550 | 565 |
lemma balance_left_inv2_app: |
35534 | 566 |
assumes "inv2 lt" "inv2 rt" "bheight lt + 1 = bheight rt" "color_of rt = B" |
35550 | 567 |
shows "inv2 (balance_left lt k v rt)" |
568 |
"bheight (balance_left lt k v rt) = bheight rt" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
569 |
using assms |
35550 | 570 |
by (induct lt k v rt rule: balance_left.induct) (auto simp add: balance_inv2 balance_bheight)+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
571 |
|
35550 | 572 |
lemma balance_left_inv1: "\<lbrakk>inv1l a; inv1 b; color_of b = B\<rbrakk> \<Longrightarrow> inv1 (balance_left a k x b)" |
573 |
by (induct a k x b rule: balance_left.induct) (simp add: balance_inv1)+ |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
574 |
|
35550 | 575 |
lemma balance_left_inv1l: "\<lbrakk> inv1l lt; inv1 rt \<rbrakk> \<Longrightarrow> inv1l (balance_left lt k x rt)" |
576 |
by (induct lt k x rt rule: balance_left.induct) (auto simp: balance_inv1) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
577 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
578 |
lemma (in linorder) balance_left_rbt_sorted: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
579 |
"\<lbrakk> rbt_sorted l; rbt_sorted r; rbt_less k l; k \<guillemotleft>| r \<rbrakk> \<Longrightarrow> rbt_sorted (balance_left l k v r)" |
35550 | 580 |
apply (induct l k v r rule: balance_left.induct) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
581 |
apply (auto simp: balance_rbt_sorted) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
582 |
apply (unfold rbt_greater_prop rbt_less_prop) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
583 |
by force+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
584 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
585 |
context order begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
586 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
587 |
lemma balance_left_rbt_greater: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
588 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
589 |
assumes "k \<guillemotleft>| a" "k \<guillemotleft>| b" "k < x" |
35550 | 590 |
shows "k \<guillemotleft>| balance_left a x t b" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
591 |
using assms |
35550 | 592 |
by (induct a x t b rule: balance_left.induct) auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
593 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
594 |
lemma balance_left_rbt_less: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
595 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
596 |
assumes "a |\<guillemotleft> k" "b |\<guillemotleft> k" "x < k" |
35550 | 597 |
shows "balance_left a x t b |\<guillemotleft> k" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
598 |
using assms |
35550 | 599 |
by (induct a x t b rule: balance_left.induct) auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
600 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
601 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
602 |
|
35550 | 603 |
lemma balance_left_in_tree: |
35534 | 604 |
assumes "inv1l l" "inv1 r" "bheight l + 1 = bheight r" |
35550 | 605 |
shows "entry_in_tree k v (balance_left l a b r) = (entry_in_tree k v l \<or> k = a \<and> v = b \<or> entry_in_tree k v r)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
606 |
using assms |
35550 | 607 |
by (induct l k v r rule: balance_left.induct) (auto simp: balance_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
608 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
609 |
fun |
35550 | 610 |
balance_right :: "('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
611 |
where |
35550 | 612 |
"balance_right a k x (Branch R b s y c) = Branch R a k x (Branch B b s y c)" | |
613 |
"balance_right (Branch B a k x b) s y bl = balance (Branch R a k x b) s y bl" | |
|
614 |
"balance_right (Branch R a k x (Branch B b s y c)) t z bl = Branch R (balance (paint R a) k x b) s y (Branch B c t z bl)" | |
|
615 |
"balance_right t k x s = Empty" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
616 |
|
35550 | 617 |
lemma balance_right_inv2_with_inv1: |
35534 | 618 |
assumes "inv2 lt" "inv2 rt" "bheight lt = bheight rt + 1" "inv1 lt" |
35550 | 619 |
shows "inv2 (balance_right lt k v rt) \<and> bheight (balance_right lt k v rt) = bheight lt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
620 |
using assms |
35550 | 621 |
by (induct lt k v rt rule: balance_right.induct) (auto simp: balance_inv2 balance_bheight) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
622 |
|
35550 | 623 |
lemma balance_right_inv1: "\<lbrakk>inv1 a; inv1l b; color_of a = B\<rbrakk> \<Longrightarrow> inv1 (balance_right a k x b)" |
624 |
by (induct a k x b rule: balance_right.induct) (simp add: balance_inv1)+ |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
625 |
|
35550 | 626 |
lemma balance_right_inv1l: "\<lbrakk> inv1 lt; inv1l rt \<rbrakk> \<Longrightarrow>inv1l (balance_right lt k x rt)" |
627 |
by (induct lt k x rt rule: balance_right.induct) (auto simp: balance_inv1) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
628 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
629 |
lemma (in linorder) balance_right_rbt_sorted: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
630 |
"\<lbrakk> rbt_sorted l; rbt_sorted r; rbt_less k l; k \<guillemotleft>| r \<rbrakk> \<Longrightarrow> rbt_sorted (balance_right l k v r)" |
35550 | 631 |
apply (induct l k v r rule: balance_right.induct) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
632 |
apply (auto simp:balance_rbt_sorted) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
633 |
apply (unfold rbt_less_prop rbt_greater_prop) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
634 |
by force+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
635 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
636 |
context order begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
637 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
638 |
lemma balance_right_rbt_greater: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
639 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
640 |
assumes "k \<guillemotleft>| a" "k \<guillemotleft>| b" "k < x" |
35550 | 641 |
shows "k \<guillemotleft>| balance_right a x t b" |
642 |
using assms by (induct a x t b rule: balance_right.induct) auto |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
643 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
644 |
lemma balance_right_rbt_less: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
645 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
646 |
assumes "a |\<guillemotleft> k" "b |\<guillemotleft> k" "x < k" |
35550 | 647 |
shows "balance_right a x t b |\<guillemotleft> k" |
648 |
using assms by (induct a x t b rule: balance_right.induct) auto |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
649 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
650 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
651 |
|
35550 | 652 |
lemma balance_right_in_tree: |
35534 | 653 |
assumes "inv1 l" "inv1l r" "bheight l = bheight r + 1" "inv2 l" "inv2 r" |
35550 | 654 |
shows "entry_in_tree x y (balance_right l k v r) = (entry_in_tree x y l \<or> x = k \<and> y = v \<or> entry_in_tree x y r)" |
655 |
using assms by (induct l k v r rule: balance_right.induct) (auto simp: balance_in_tree) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
656 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
657 |
fun |
35550 | 658 |
combine :: "('a,'b) rbt \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
659 |
where |
35550 | 660 |
"combine Empty x = x" |
661 |
| "combine x Empty = x" |
|
662 |
| "combine (Branch R a k x b) (Branch R c s y d) = (case (combine b c) of |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
663 |
Branch R b2 t z c2 \<Rightarrow> (Branch R (Branch R a k x b2) t z (Branch R c2 s y d)) | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
664 |
bc \<Rightarrow> Branch R a k x (Branch R bc s y d))" |
35550 | 665 |
| "combine (Branch B a k x b) (Branch B c s y d) = (case (combine b c) of |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
666 |
Branch R b2 t z c2 \<Rightarrow> Branch R (Branch B a k x b2) t z (Branch B c2 s y d) | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
667 |
bc \<Rightarrow> balance_left a k x (Branch B bc s y d))" |
35550 | 668 |
| "combine a (Branch R b k x c) = Branch R (combine a b) k x c" |
669 |
| "combine (Branch R a k x b) c = Branch R a k x (combine b c)" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
670 |
|
35550 | 671 |
lemma combine_inv2: |
35534 | 672 |
assumes "inv2 lt" "inv2 rt" "bheight lt = bheight rt" |
35550 | 673 |
shows "bheight (combine lt rt) = bheight lt" "inv2 (combine lt rt)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
674 |
using assms |
35550 | 675 |
by (induct lt rt rule: combine.induct) |
676 |
(auto simp: balance_left_inv2_app split: rbt.splits color.splits) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
677 |
|
35550 | 678 |
lemma combine_inv1: |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
679 |
assumes "inv1 lt" "inv1 rt" |
35550 | 680 |
shows "color_of lt = B \<Longrightarrow> color_of rt = B \<Longrightarrow> inv1 (combine lt rt)" |
681 |
"inv1l (combine lt rt)" |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
682 |
using assms |
35550 | 683 |
by (induct lt rt rule: combine.induct) |
684 |
(auto simp: balance_left_inv1 split: rbt.splits color.splits) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
685 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
686 |
context linorder begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
687 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
688 |
lemma combine_rbt_greater[simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
689 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
690 |
assumes "k \<guillemotleft>| l" "k \<guillemotleft>| r" |
35550 | 691 |
shows "k \<guillemotleft>| combine l r" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
692 |
using assms |
35550 | 693 |
by (induct l r rule: combine.induct) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
694 |
(auto simp: balance_left_rbt_greater split:rbt.splits color.splits) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
695 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
696 |
lemma combine_rbt_less[simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
697 |
fixes k :: "'a" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
698 |
assumes "l |\<guillemotleft> k" "r |\<guillemotleft> k" |
35550 | 699 |
shows "combine l r |\<guillemotleft> k" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
700 |
using assms |
35550 | 701 |
by (induct l r rule: combine.induct) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
702 |
(auto simp: balance_left_rbt_less split:rbt.splits color.splits) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
703 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
704 |
lemma combine_rbt_sorted: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
705 |
fixes k :: "'a" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
706 |
assumes "rbt_sorted l" "rbt_sorted r" "l |\<guillemotleft> k" "k \<guillemotleft>| r" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
707 |
shows "rbt_sorted (combine l r)" |
35550 | 708 |
using assms proof (induct l r rule: combine.induct) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
709 |
case (3 a x v b c y w d) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
710 |
hence ineqs: "a |\<guillemotleft> x" "x \<guillemotleft>| b" "b |\<guillemotleft> k" "k \<guillemotleft>| c" "c |\<guillemotleft> y" "y \<guillemotleft>| d" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
711 |
by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
712 |
with 3 |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
713 |
show ?case |
35550 | 714 |
by (cases "combine b c" rule: rbt_cases) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
715 |
(auto, (metis combine_rbt_greater combine_rbt_less ineqs ineqs rbt_less_simps(2) rbt_greater_simps(2) rbt_greater_trans rbt_less_trans)+) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
716 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
717 |
case (4 a x v b c y w d) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
718 |
hence "x < k \<and> rbt_greater k c" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
719 |
hence "rbt_greater x c" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
720 |
with 4 have 2: "rbt_greater x (combine b c)" by (simp add: combine_rbt_greater) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
721 |
from 4 have "k < y \<and> rbt_less k b" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
722 |
hence "rbt_less y b" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
723 |
with 4 have 3: "rbt_less y (combine b c)" by (simp add: combine_rbt_less) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
724 |
show ?case |
35550 | 725 |
proof (cases "combine b c" rule: rbt_cases) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
726 |
case Empty |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
727 |
from 4 have "x < y \<and> rbt_greater y d" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
728 |
hence "rbt_greater x d" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
729 |
with 4 Empty have "rbt_sorted a" and "rbt_sorted (Branch B Empty y w d)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
730 |
and "rbt_less x a" and "rbt_greater x (Branch B Empty y w d)" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
731 |
with Empty show ?thesis by (simp add: balance_left_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
732 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
733 |
case (Red lta va ka rta) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
734 |
with 2 4 have "x < va \<and> rbt_less x a" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
735 |
hence 5: "rbt_less va a" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
736 |
from Red 3 4 have "va < y \<and> rbt_greater y d" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
737 |
hence "rbt_greater va d" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
738 |
with Red 2 3 4 5 show ?thesis by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
739 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
740 |
case (Black lta va ka rta) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
741 |
from 4 have "x < y \<and> rbt_greater y d" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
742 |
hence "rbt_greater x d" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
743 |
with Black 2 3 4 have "rbt_sorted a" and "rbt_sorted (Branch B (combine b c) y w d)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
744 |
and "rbt_less x a" and "rbt_greater x (Branch B (combine b c) y w d)" by auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
745 |
with Black show ?thesis by (simp add: balance_left_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
746 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
747 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
748 |
case (5 va vb vd vc b x w c) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
749 |
hence "k < x \<and> rbt_less k (Branch B va vb vd vc)" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
750 |
hence "rbt_less x (Branch B va vb vd vc)" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
751 |
with 5 show ?case by (simp add: combine_rbt_less) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
752 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
753 |
case (6 a x v b va vb vd vc) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
754 |
hence "x < k \<and> rbt_greater k (Branch B va vb vd vc)" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
755 |
hence "rbt_greater x (Branch B va vb vd vc)" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
756 |
with 6 show ?case by (simp add: combine_rbt_greater) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
757 |
qed simp+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
758 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
759 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
760 |
|
35550 | 761 |
lemma combine_in_tree: |
35534 | 762 |
assumes "inv2 l" "inv2 r" "bheight l = bheight r" "inv1 l" "inv1 r" |
35550 | 763 |
shows "entry_in_tree k v (combine l r) = (entry_in_tree k v l \<or> entry_in_tree k v r)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
764 |
using assms |
35550 | 765 |
proof (induct l r rule: combine.induct) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
766 |
case (4 _ _ _ b c) |
35550 | 767 |
hence a: "bheight (combine b c) = bheight b" by (simp add: combine_inv2) |
768 |
from 4 have b: "inv1l (combine b c)" by (simp add: combine_inv1) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
769 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
770 |
show ?case |
35550 | 771 |
proof (cases "combine b c" rule: rbt_cases) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
772 |
case Empty |
35550 | 773 |
with 4 a show ?thesis by (auto simp: balance_left_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
774 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
775 |
case (Red lta ka va rta) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
776 |
with 4 show ?thesis by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
777 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
778 |
case (Black lta ka va rta) |
35550 | 779 |
with a b 4 show ?thesis by (auto simp: balance_left_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
780 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
781 |
qed (auto split: rbt.splits color.splits) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
782 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
783 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
784 |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
785 |
fun |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
786 |
rbt_del_from_left :: "'a \<Rightarrow> ('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" and |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
787 |
rbt_del_from_right :: "'a \<Rightarrow> ('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" and |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
788 |
rbt_del :: "'a\<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
789 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
790 |
"rbt_del x Empty = Empty" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
791 |
"rbt_del x (Branch c a y s b) = |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
792 |
(if x < y then rbt_del_from_left x a y s b |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
793 |
else (if x > y then rbt_del_from_right x a y s b else combine a b))" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
794 |
"rbt_del_from_left x (Branch B lt z v rt) y s b = balance_left (rbt_del x (Branch B lt z v rt)) y s b" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
795 |
"rbt_del_from_left x a y s b = Branch R (rbt_del x a) y s b" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
796 |
"rbt_del_from_right x a y s (Branch B lt z v rt) = balance_right a y s (rbt_del x (Branch B lt z v rt))" | |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
797 |
"rbt_del_from_right x a y s b = Branch R a y s (rbt_del x b)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
798 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
799 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
800 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
801 |
context linorder begin |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
802 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
803 |
lemma |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
804 |
assumes "inv2 lt" "inv1 lt" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
805 |
shows |
35534 | 806 |
"\<lbrakk>inv2 rt; bheight lt = bheight rt; inv1 rt\<rbrakk> \<Longrightarrow> |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
807 |
inv2 (rbt_del_from_left x lt k v rt) \<and> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
808 |
bheight (rbt_del_from_left x lt k v rt) = bheight lt \<and> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
809 |
(color_of lt = B \<and> color_of rt = B \<and> inv1 (rbt_del_from_left x lt k v rt) \<or> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
810 |
(color_of lt \<noteq> B \<or> color_of rt \<noteq> B) \<and> inv1l (rbt_del_from_left x lt k v rt))" |
35534 | 811 |
and "\<lbrakk>inv2 rt; bheight lt = bheight rt; inv1 rt\<rbrakk> \<Longrightarrow> |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
812 |
inv2 (rbt_del_from_right x lt k v rt) \<and> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
813 |
bheight (rbt_del_from_right x lt k v rt) = bheight lt \<and> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
814 |
(color_of lt = B \<and> color_of rt = B \<and> inv1 (rbt_del_from_right x lt k v rt) \<or> |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
815 |
(color_of lt \<noteq> B \<or> color_of rt \<noteq> B) \<and> inv1l (rbt_del_from_right x lt k v rt))" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
816 |
and rbt_del_inv1_inv2: "inv2 (rbt_del x lt) \<and> (color_of lt = R \<and> bheight (rbt_del x lt) = bheight lt \<and> inv1 (rbt_del x lt) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
817 |
\<or> color_of lt = B \<and> bheight (rbt_del x lt) = bheight lt - 1 \<and> inv1l (rbt_del x lt))" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
818 |
using assms |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
819 |
proof (induct x lt k v rt and x lt k v rt and x lt rule: rbt_del_from_left_rbt_del_from_right_rbt_del.induct) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
820 |
case (2 y c _ y') |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
821 |
have "y = y' \<or> y < y' \<or> y > y'" by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
822 |
thus ?case proof (elim disjE) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
823 |
assume "y = y'" |
35550 | 824 |
with 2 show ?thesis by (cases c) (simp add: combine_inv2 combine_inv1)+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
825 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
826 |
assume "y < y'" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
827 |
with 2 show ?thesis by (cases c) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
828 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
829 |
assume "y' < y" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
830 |
with 2 show ?thesis by (cases c) auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
831 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
832 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
833 |
case (3 y lt z v rta y' ss bb) |
35550 | 834 |
thus ?case by (cases "color_of (Branch B lt z v rta) = B \<and> color_of bb = B") (simp add: balance_left_inv2_with_inv1 balance_left_inv1 balance_left_inv1l)+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
835 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
836 |
case (5 y a y' ss lt z v rta) |
35550 | 837 |
thus ?case by (cases "color_of a = B \<and> color_of (Branch B lt z v rta) = B") (simp add: balance_right_inv2_with_inv1 balance_right_inv1 balance_right_inv1l)+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
838 |
next |
35534 | 839 |
case ("6_1" y a y' ss) thus ?case by (cases "color_of a = B \<and> color_of Empty = B") simp+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
840 |
qed auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
841 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
842 |
lemma |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
843 |
rbt_del_from_left_rbt_less: "\<lbrakk> lt |\<guillemotleft> v; rt |\<guillemotleft> v; k < v\<rbrakk> \<Longrightarrow> rbt_del_from_left x lt k y rt |\<guillemotleft> v" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
844 |
and rbt_del_from_right_rbt_less: "\<lbrakk>lt |\<guillemotleft> v; rt |\<guillemotleft> v; k < v\<rbrakk> \<Longrightarrow> rbt_del_from_right x lt k y rt |\<guillemotleft> v" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
845 |
and rbt_del_rbt_less: "lt |\<guillemotleft> v \<Longrightarrow> rbt_del x lt |\<guillemotleft> v" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
846 |
by (induct x lt k y rt and x lt k y rt and x lt rule: rbt_del_from_left_rbt_del_from_right_rbt_del.induct) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
847 |
(auto simp: balance_left_rbt_less balance_right_rbt_less) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
848 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
849 |
lemma rbt_del_from_left_rbt_greater: "\<lbrakk>v \<guillemotleft>| lt; v \<guillemotleft>| rt; k > v\<rbrakk> \<Longrightarrow> v \<guillemotleft>| rbt_del_from_left x lt k y rt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
850 |
and rbt_del_from_right_rbt_greater: "\<lbrakk>v \<guillemotleft>| lt; v \<guillemotleft>| rt; k > v\<rbrakk> \<Longrightarrow> v \<guillemotleft>| rbt_del_from_right x lt k y rt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
851 |
and rbt_del_rbt_greater: "v \<guillemotleft>| lt \<Longrightarrow> v \<guillemotleft>| rbt_del x lt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
852 |
by (induct x lt k y rt and x lt k y rt and x lt rule: rbt_del_from_left_rbt_del_from_right_rbt_del.induct) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
853 |
(auto simp: balance_left_rbt_greater balance_right_rbt_greater) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
854 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
855 |
lemma "\<lbrakk>rbt_sorted lt; rbt_sorted rt; lt |\<guillemotleft> k; k \<guillemotleft>| rt\<rbrakk> \<Longrightarrow> rbt_sorted (rbt_del_from_left x lt k y rt)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
856 |
and "\<lbrakk>rbt_sorted lt; rbt_sorted rt; lt |\<guillemotleft> k; k \<guillemotleft>| rt\<rbrakk> \<Longrightarrow> rbt_sorted (rbt_del_from_right x lt k y rt)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
857 |
and rbt_del_rbt_sorted: "rbt_sorted lt \<Longrightarrow> rbt_sorted (rbt_del x lt)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
858 |
proof (induct x lt k y rt and x lt k y rt and x lt rule: rbt_del_from_left_rbt_del_from_right_rbt_del.induct) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
859 |
case (3 x lta zz v rta yy ss bb) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
860 |
from 3 have "Branch B lta zz v rta |\<guillemotleft> yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
861 |
hence "rbt_del x (Branch B lta zz v rta) |\<guillemotleft> yy" by (rule rbt_del_rbt_less) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
862 |
with 3 show ?case by (simp add: balance_left_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
863 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
864 |
case ("4_2" x vaa vbb vdd vc yy ss bb) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
865 |
hence "Branch R vaa vbb vdd vc |\<guillemotleft> yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
866 |
hence "rbt_del x (Branch R vaa vbb vdd vc) |\<guillemotleft> yy" by (rule rbt_del_rbt_less) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
867 |
with "4_2" show ?case by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
868 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
869 |
case (5 x aa yy ss lta zz v rta) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
870 |
hence "yy \<guillemotleft>| Branch B lta zz v rta" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
871 |
hence "yy \<guillemotleft>| rbt_del x (Branch B lta zz v rta)" by (rule rbt_del_rbt_greater) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
872 |
with 5 show ?case by (simp add: balance_right_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
873 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
874 |
case ("6_2" x aa yy ss vaa vbb vdd vc) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
875 |
hence "yy \<guillemotleft>| Branch R vaa vbb vdd vc" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
876 |
hence "yy \<guillemotleft>| rbt_del x (Branch R vaa vbb vdd vc)" by (rule rbt_del_rbt_greater) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
877 |
with "6_2" show ?case by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
878 |
qed (auto simp: combine_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
879 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
880 |
lemma "\<lbrakk>rbt_sorted lt; rbt_sorted rt; lt |\<guillemotleft> kt; kt \<guillemotleft>| rt; inv1 lt; inv1 rt; inv2 lt; inv2 rt; bheight lt = bheight rt; x < kt\<rbrakk> \<Longrightarrow> entry_in_tree k v (rbt_del_from_left x lt kt y rt) = (False \<or> (x \<noteq> k \<and> entry_in_tree k v (Branch c lt kt y rt)))" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
881 |
and "\<lbrakk>rbt_sorted lt; rbt_sorted rt; lt |\<guillemotleft> kt; kt \<guillemotleft>| rt; inv1 lt; inv1 rt; inv2 lt; inv2 rt; bheight lt = bheight rt; x > kt\<rbrakk> \<Longrightarrow> entry_in_tree k v (rbt_del_from_right x lt kt y rt) = (False \<or> (x \<noteq> k \<and> entry_in_tree k v (Branch c lt kt y rt)))" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
882 |
and rbt_del_in_tree: "\<lbrakk>rbt_sorted t; inv1 t; inv2 t\<rbrakk> \<Longrightarrow> entry_in_tree k v (rbt_del x t) = (False \<or> (x \<noteq> k \<and> entry_in_tree k v t))" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
883 |
proof (induct x lt kt y rt and x lt kt y rt and x t rule: rbt_del_from_left_rbt_del_from_right_rbt_del.induct) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
884 |
case (2 xx c aa yy ss bb) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
885 |
have "xx = yy \<or> xx < yy \<or> xx > yy" by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
886 |
from this 2 show ?case proof (elim disjE) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
887 |
assume "xx = yy" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
888 |
with 2 show ?thesis proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
889 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
890 |
from 2 `xx = yy` `xx = k` have "rbt_sorted (Branch c aa yy ss bb) \<and> k = yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
891 |
hence "\<not> entry_in_tree k v aa" "\<not> entry_in_tree k v bb" by (auto simp: rbt_less_nit rbt_greater_prop) |
35550 | 892 |
with `xx = yy` 2 `xx = k` show ?thesis by (simp add: combine_in_tree) |
893 |
qed (simp add: combine_in_tree) |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
894 |
qed simp+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
895 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
896 |
case (3 xx lta zz vv rta yy ss bb) |
35534 | 897 |
def mt[simp]: mt == "Branch B lta zz vv rta" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
898 |
from 3 have "inv2 mt \<and> inv1 mt" by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
899 |
hence "inv2 (rbt_del xx mt) \<and> (color_of mt = R \<and> bheight (rbt_del xx mt) = bheight mt \<and> inv1 (rbt_del xx mt) \<or> color_of mt = B \<and> bheight (rbt_del xx mt) = bheight mt - 1 \<and> inv1l (rbt_del xx mt))" by (blast dest: rbt_del_inv1_inv2) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
900 |
with 3 have 4: "entry_in_tree k v (rbt_del_from_left xx mt yy ss bb) = (False \<or> xx \<noteq> k \<and> entry_in_tree k v mt \<or> (k = yy \<and> v = ss) \<or> entry_in_tree k v bb)" by (simp add: balance_left_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
901 |
thus ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
902 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
903 |
from 3 True have "yy \<guillemotleft>| bb \<and> yy > k" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
904 |
hence "k \<guillemotleft>| bb" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
905 |
with 3 4 True show ?thesis by (auto simp: rbt_greater_nit) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
906 |
qed auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
907 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
908 |
case ("4_1" xx yy ss bb) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
909 |
show ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
910 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
911 |
with "4_1" have "yy \<guillemotleft>| bb \<and> k < yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
912 |
hence "k \<guillemotleft>| bb" by (blast dest: rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
913 |
with "4_1" `xx = k` |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
914 |
have "entry_in_tree k v (Branch R Empty yy ss bb) = entry_in_tree k v Empty" by (auto simp: rbt_greater_nit) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
915 |
thus ?thesis by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
916 |
qed simp+ |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
917 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
918 |
case ("4_2" xx vaa vbb vdd vc yy ss bb) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
919 |
thus ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
920 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
921 |
with "4_2" have "k < yy \<and> yy \<guillemotleft>| bb" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
922 |
hence "k \<guillemotleft>| bb" by (blast dest: rbt_greater_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
923 |
with True "4_2" show ?thesis by (auto simp: rbt_greater_nit) |
35550 | 924 |
qed auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
925 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
926 |
case (5 xx aa yy ss lta zz vv rta) |
35534 | 927 |
def mt[simp]: mt == "Branch B lta zz vv rta" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
928 |
from 5 have "inv2 mt \<and> inv1 mt" by simp |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
929 |
hence "inv2 (rbt_del xx mt) \<and> (color_of mt = R \<and> bheight (rbt_del xx mt) = bheight mt \<and> inv1 (rbt_del xx mt) \<or> color_of mt = B \<and> bheight (rbt_del xx mt) = bheight mt - 1 \<and> inv1l (rbt_del xx mt))" by (blast dest: rbt_del_inv1_inv2) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
930 |
with 5 have 3: "entry_in_tree k v (rbt_del_from_right xx aa yy ss mt) = (entry_in_tree k v aa \<or> (k = yy \<and> v = ss) \<or> False \<or> xx \<noteq> k \<and> entry_in_tree k v mt)" by (simp add: balance_right_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
931 |
thus ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
932 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
933 |
from 5 True have "aa |\<guillemotleft> yy \<and> yy < k" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
934 |
hence "aa |\<guillemotleft> k" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
935 |
with 3 5 True show ?thesis by (auto simp: rbt_less_nit) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
936 |
qed auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
937 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
938 |
case ("6_1" xx aa yy ss) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
939 |
show ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
940 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
941 |
with "6_1" have "aa |\<guillemotleft> yy \<and> k > yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
942 |
hence "aa |\<guillemotleft> k" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
943 |
with "6_1" `xx = k` show ?thesis by (auto simp: rbt_less_nit) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
944 |
qed simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
945 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
946 |
case ("6_2" xx aa yy ss vaa vbb vdd vc) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
947 |
thus ?case proof (cases "xx = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
948 |
case True |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
949 |
with "6_2" have "k > yy \<and> aa |\<guillemotleft> yy" by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
950 |
hence "aa |\<guillemotleft> k" by (blast dest: rbt_less_trans) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
951 |
with True "6_2" show ?thesis by (auto simp: rbt_less_nit) |
35550 | 952 |
qed auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
953 |
qed simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
954 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
955 |
definition (in ord) rbt_delete where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
956 |
"rbt_delete k t = paint B (rbt_del k t)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
957 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
958 |
theorem rbt_delete_is_rbt [simp]: assumes "is_rbt t" shows "is_rbt (rbt_delete k t)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
959 |
proof - |
35534 | 960 |
from assms have "inv2 t" and "inv1 t" unfolding is_rbt_def by auto |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
961 |
hence "inv2 (rbt_del k t) \<and> (color_of t = R \<and> bheight (rbt_del k t) = bheight t \<and> inv1 (rbt_del k t) \<or> color_of t = B \<and> bheight (rbt_del k t) = bheight t - 1 \<and> inv1l (rbt_del k t))" by (rule rbt_del_inv1_inv2) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
962 |
hence "inv2 (rbt_del k t) \<and> inv1l (rbt_del k t)" by (cases "color_of t") auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
963 |
with assms show ?thesis |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
964 |
unfolding is_rbt_def rbt_delete_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
965 |
by (auto intro: paint_rbt_sorted rbt_del_rbt_sorted) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
966 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
967 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
968 |
lemma rbt_delete_in_tree: |
35534 | 969 |
assumes "is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
970 |
shows "entry_in_tree k v (rbt_delete x t) = (x \<noteq> k \<and> entry_in_tree k v t)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
971 |
using assms unfolding is_rbt_def rbt_delete_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
972 |
by (auto simp: rbt_del_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
973 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
974 |
lemma rbt_lookup_rbt_delete: |
35534 | 975 |
assumes is_rbt: "is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
976 |
shows "rbt_lookup (rbt_delete k t) = (rbt_lookup t)|`(-{k})" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
977 |
proof |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
978 |
fix x |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
979 |
show "rbt_lookup (rbt_delete k t) x = (rbt_lookup t |` (-{k})) x" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
980 |
proof (cases "x = k") |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
981 |
assume "x = k" |
35534 | 982 |
with is_rbt show ?thesis |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
983 |
by (cases "rbt_lookup (rbt_delete k t) k") (auto simp: rbt_lookup_in_tree rbt_delete_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
984 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
985 |
assume "x \<noteq> k" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
986 |
thus ?thesis |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
987 |
by auto (metis is_rbt rbt_delete_is_rbt rbt_delete_in_tree is_rbt_rbt_sorted rbt_lookup_from_in_tree) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
988 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
989 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
990 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
991 |
end |
35550 | 992 |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
993 |
subsection {* Union *} |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
994 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
995 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
996 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
997 |
primrec rbt_union_with_key :: "('a \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
998 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
999 |
"rbt_union_with_key f t Empty = t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1000 |
| "rbt_union_with_key f t (Branch c lt k v rt) = rbt_union_with_key f (rbt_union_with_key f (rbt_insert_with_key f k v t) lt) rt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1001 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1002 |
definition rbt_union_with where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1003 |
"rbt_union_with f = rbt_union_with_key (\<lambda>_. f)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1004 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1005 |
definition rbt_union where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1006 |
"rbt_union = rbt_union_with_key (%_ _ rv. rv)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1007 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1008 |
end |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1009 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1010 |
context linorder begin |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1011 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1012 |
lemma rbt_unionwk_rbt_sorted: "rbt_sorted lt \<Longrightarrow> rbt_sorted (rbt_union_with_key f lt rt)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1013 |
by (induct rt arbitrary: lt) (auto simp: rbt_insertwk_rbt_sorted) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1014 |
theorem rbt_unionwk_is_rbt[simp]: "is_rbt lt \<Longrightarrow> is_rbt (rbt_union_with_key f lt rt)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1015 |
by (induct rt arbitrary: lt) (simp add: rbt_insertwk_is_rbt)+ |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1016 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1017 |
theorem rbt_unionw_is_rbt: "is_rbt lt \<Longrightarrow> is_rbt (rbt_union_with f lt rt)" unfolding rbt_union_with_def by simp |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1018 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1019 |
theorem rbt_union_is_rbt: "is_rbt lt \<Longrightarrow> is_rbt (rbt_union lt rt)" unfolding rbt_union_def by simp |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1020 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1021 |
lemma (in ord) rbt_union_Branch[simp]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1022 |
"rbt_union t (Branch c lt k v rt) = rbt_union (rbt_union (rbt_insert k v t) lt) rt" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1023 |
unfolding rbt_union_def rbt_insert_def |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1024 |
by simp |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1025 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1026 |
lemma rbt_lookup_rbt_union: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1027 |
assumes "is_rbt s" "rbt_sorted t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1028 |
shows "rbt_lookup (rbt_union s t) = rbt_lookup s ++ rbt_lookup t" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1029 |
using assms |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1030 |
proof (induct t arbitrary: s) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1031 |
case Empty thus ?case by (auto simp: rbt_union_def) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1032 |
next |
35534 | 1033 |
case (Branch c l k v r s) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1034 |
then have "rbt_sorted r" "rbt_sorted l" "l |\<guillemotleft> k" "k \<guillemotleft>| r" by auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1035 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1036 |
have meq: "rbt_lookup s(k \<mapsto> v) ++ rbt_lookup l ++ rbt_lookup r = |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1037 |
rbt_lookup s ++ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1038 |
(\<lambda>a. if a < k then rbt_lookup l a |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1039 |
else if k < a then rbt_lookup r a else Some v)" (is "?m1 = ?m2") |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1040 |
proof (rule ext) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1041 |
fix a |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1042 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1043 |
have "k < a \<or> k = a \<or> k > a" by auto |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1044 |
thus "?m1 a = ?m2 a" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1045 |
proof (elim disjE) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1046 |
assume "k < a" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1047 |
with `l |\<guillemotleft> k` have "l |\<guillemotleft> a" by (rule rbt_less_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1048 |
with `k < a` show ?thesis |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1049 |
by (auto simp: map_add_def split: option.splits) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1050 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1051 |
assume "k = a" |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1052 |
with `l |\<guillemotleft> k` `k \<guillemotleft>| r` |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1053 |
show ?thesis by (auto simp: map_add_def) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1054 |
next |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1055 |
assume "a < k" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1056 |
from this `k \<guillemotleft>| r` have "a \<guillemotleft>| r" by (rule rbt_greater_trans) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1057 |
with `a < k` show ?thesis |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1058 |
by (auto simp: map_add_def split: option.splits) |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1059 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1060 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1061 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1062 |
from Branch have is_rbt: "is_rbt (RBT_Impl.rbt_union (RBT_Impl.rbt_insert k v s) l)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1063 |
by (auto intro: rbt_union_is_rbt rbt_insert_is_rbt) |
35550 | 1064 |
with Branch have IHs: |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1065 |
"rbt_lookup (rbt_union (rbt_union (rbt_insert k v s) l) r) = rbt_lookup (rbt_union (rbt_insert k v s) l) ++ rbt_lookup r" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1066 |
"rbt_lookup (rbt_union (rbt_insert k v s) l) = rbt_lookup (rbt_insert k v s) ++ rbt_lookup l" |
35550 | 1067 |
by auto |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1068 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1069 |
with meq show ?case |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1070 |
by (auto simp: rbt_lookup_rbt_insert[OF Branch(3)]) |
35550 | 1071 |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1072 |
qed |
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1073 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1074 |
end |
35550 | 1075 |
|
1076 |
subsection {* Modifying existing entries *} |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1077 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1078 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1079 |
|
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1080 |
primrec |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1081 |
rbt_map_entry :: "'a \<Rightarrow> ('b \<Rightarrow> 'b) \<Rightarrow> ('a, 'b) rbt \<Rightarrow> ('a, 'b) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1082 |
where |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1083 |
"rbt_map_entry k f Empty = Empty" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1084 |
| "rbt_map_entry k f (Branch c lt x v rt) = |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1085 |
(if k < x then Branch c (rbt_map_entry k f lt) x v rt |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1086 |
else if k > x then (Branch c lt x v (rbt_map_entry k f rt)) |
35602 | 1087 |
else Branch c lt x (f v) rt)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1088 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1089 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1090 |
lemma rbt_map_entry_color_of: "color_of (rbt_map_entry k f t) = color_of t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1091 |
lemma rbt_map_entry_inv1: "inv1 (rbt_map_entry k f t) = inv1 t" by (induct t) (simp add: rbt_map_entry_color_of)+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1092 |
lemma rbt_map_entry_inv2: "inv2 (rbt_map_entry k f t) = inv2 t" "bheight (rbt_map_entry k f t) = bheight t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1093 |
lemma rbt_map_entry_rbt_greater: "rbt_greater a (rbt_map_entry k f t) = rbt_greater a t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1094 |
lemma rbt_map_entry_rbt_less: "rbt_less a (rbt_map_entry k f t) = rbt_less a t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1095 |
lemma rbt_map_entry_rbt_sorted: "rbt_sorted (rbt_map_entry k f t) = rbt_sorted t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1096 |
by (induct t) (simp_all add: rbt_map_entry_rbt_less rbt_map_entry_rbt_greater) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1097 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1098 |
theorem rbt_map_entry_is_rbt [simp]: "is_rbt (rbt_map_entry k f t) = is_rbt t" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1099 |
unfolding is_rbt_def by (simp add: rbt_map_entry_inv2 rbt_map_entry_color_of rbt_map_entry_rbt_sorted rbt_map_entry_inv1 ) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1100 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1101 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1102 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1103 |
theorem (in linorder) rbt_lookup_rbt_map_entry: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1104 |
"rbt_lookup (rbt_map_entry k f t) = (rbt_lookup t)(k := Option.map f (rbt_lookup t k))" |
39302
d7728f65b353
renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents:
39198
diff
changeset
|
1105 |
by (induct t) (auto split: option.splits simp add: fun_eq_iff) |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1106 |
|
35550 | 1107 |
subsection {* Mapping all entries *} |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1108 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1109 |
primrec |
35602 | 1110 |
map :: "('a \<Rightarrow> 'b \<Rightarrow> 'c) \<Rightarrow> ('a, 'b) rbt \<Rightarrow> ('a, 'c) rbt" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1111 |
where |
35550 | 1112 |
"map f Empty = Empty" |
1113 |
| "map f (Branch c lt k v rt) = Branch c (map f lt) k (f k v) (map f rt)" |
|
32237
cdc76a42fed4
added missing proof of RBT.map_of_alist_of (contributed by Peter Lammich)
krauss
parents:
30738
diff
changeset
|
1114 |
|
35550 | 1115 |
lemma map_entries [simp]: "entries (map f t) = List.map (\<lambda>(k, v). (k, f k v)) (entries t)" |
1116 |
by (induct t) auto |
|
1117 |
lemma map_keys [simp]: "keys (map f t) = keys t" by (simp add: keys_def split_def) |
|
1118 |
lemma map_color_of: "color_of (map f t) = color_of t" by (induct t) simp+ |
|
1119 |
lemma map_inv1: "inv1 (map f t) = inv1 t" by (induct t) (simp add: map_color_of)+ |
|
1120 |
lemma map_inv2: "inv2 (map f t) = inv2 t" "bheight (map f t) = bheight t" by (induct t) simp+ |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1121 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1122 |
context ord begin |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1123 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1124 |
lemma map_rbt_greater: "rbt_greater k (map f t) = rbt_greater k t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1125 |
lemma map_rbt_less: "rbt_less k (map f t) = rbt_less k t" by (induct t) simp+ |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1126 |
lemma map_rbt_sorted: "rbt_sorted (map f t) = rbt_sorted t" by (induct t) (simp add: map_rbt_less map_rbt_greater)+ |
35550 | 1127 |
theorem map_is_rbt [simp]: "is_rbt (map f t) = is_rbt t" |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1128 |
unfolding is_rbt_def by (simp add: map_inv1 map_inv2 map_rbt_sorted map_color_of) |
32237
cdc76a42fed4
added missing proof of RBT.map_of_alist_of (contributed by Peter Lammich)
krauss
parents:
30738
diff
changeset
|
1129 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1130 |
end |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1131 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1132 |
theorem (in linorder) rbt_lookup_map: "rbt_lookup (map f t) x = Option.map (f x) (rbt_lookup t x)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1133 |
apply(induct t) |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1134 |
apply auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1135 |
apply(subgoal_tac "x = a") |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1136 |
apply auto |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1137 |
done |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1138 |
(* FIXME: simproc "antisym less" does not work for linorder context, only for linorder type class |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1139 |
by (induct t) auto *) |
35550 | 1140 |
|
1141 |
subsection {* Folding over entries *} |
|
1142 |
||
1143 |
definition fold :: "('a \<Rightarrow> 'b \<Rightarrow> 'c \<Rightarrow> 'c) \<Rightarrow> ('a, 'b) rbt \<Rightarrow> 'c \<Rightarrow> 'c" where |
|
46133
d9fe85d3d2cd
incorporated canonical fold combinator on lists into body of List theory; refactored passages on List.fold(l/r)
haftmann
parents:
45990
diff
changeset
|
1144 |
"fold f t = List.fold (prod_case f) (entries t)" |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1145 |
|
35550 | 1146 |
lemma fold_simps [simp, code]: |
1147 |
"fold f Empty = id" |
|
1148 |
"fold f (Branch c lt k v rt) = fold f rt \<circ> f k v \<circ> fold f lt" |
|
39302
d7728f65b353
renamed lemmas: ext_iff -> fun_eq_iff, set_ext_iff -> set_eq_iff, set_ext -> set_eqI
nipkow
parents:
39198
diff
changeset
|
1149 |
by (simp_all add: fold_def fun_eq_iff) |
35534 | 1150 |
|
35606 | 1151 |
|
1152 |
subsection {* Bulkloading a tree *} |
|
1153 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1154 |
definition (in ord) rbt_bulkload :: "('a \<times> 'b) list \<Rightarrow> ('a, 'b) rbt" where |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1155 |
"rbt_bulkload xs = foldr (\<lambda>(k, v). rbt_insert k v) xs Empty" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1156 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1157 |
context linorder begin |
35606 | 1158 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1159 |
lemma rbt_bulkload_is_rbt [simp, intro]: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1160 |
"is_rbt (rbt_bulkload xs)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1161 |
unfolding rbt_bulkload_def by (induct xs) auto |
35606 | 1162 |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1163 |
lemma rbt_lookup_rbt_bulkload: |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1164 |
"rbt_lookup (rbt_bulkload xs) = map_of xs" |
35606 | 1165 |
proof - |
1166 |
obtain ys where "ys = rev xs" by simp |
|
1167 |
have "\<And>t. is_rbt t \<Longrightarrow> |
|
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1168 |
rbt_lookup (List.fold (prod_case rbt_insert) ys t) = rbt_lookup t ++ map_of (rev ys)" |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1169 |
by (induct ys) (simp_all add: rbt_bulkload_def rbt_lookup_rbt_insert prod_case_beta) |
35606 | 1170 |
from this Empty_is_rbt have |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1171 |
"rbt_lookup (List.fold (prod_case rbt_insert) (rev xs) Empty) = rbt_lookup Empty ++ map_of xs" |
35606 | 1172 |
by (simp add: `ys = rev xs`) |
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1173 |
then show ?thesis by (simp add: rbt_bulkload_def rbt_lookup_Empty foldr_conv_fold) |
35606 | 1174 |
qed |
1175 |
||
47450
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1176 |
end |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1177 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1178 |
lemmas [code] = |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1179 |
ord.rbt_less_prop |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1180 |
ord.rbt_greater_prop |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1181 |
ord.rbt_sorted.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1182 |
ord.rbt_lookup.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1183 |
ord.is_rbt_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1184 |
ord.rbt_ins.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1185 |
ord.rbt_insert_with_key_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1186 |
ord.rbt_insertw_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1187 |
ord.rbt_insert_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1188 |
ord.rbt_del_from_left.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1189 |
ord.rbt_del_from_right.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1190 |
ord.rbt_del.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1191 |
ord.rbt_delete_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1192 |
ord.rbt_union_with_key.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1193 |
ord.rbt_union_with_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1194 |
ord.rbt_union_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1195 |
ord.rbt_map_entry.simps |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1196 |
ord.rbt_bulkload_def |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1197 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1198 |
text {* Restore original type constraints for constants *} |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1199 |
setup {* |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1200 |
fold Sign.add_const_constraint |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1201 |
[(@{const_name rbt_less}, SOME @{typ "('a :: order) \<Rightarrow> ('a, 'b) rbt \<Rightarrow> bool"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1202 |
(@{const_name rbt_greater}, SOME @{typ "('a :: order) \<Rightarrow> ('a, 'b) rbt \<Rightarrow> bool"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1203 |
(@{const_name rbt_sorted}, SOME @{typ "('a :: linorder, 'b) rbt \<Rightarrow> bool"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1204 |
(@{const_name rbt_lookup}, SOME @{typ "('a :: linorder, 'b) rbt \<Rightarrow> 'a \<rightharpoonup> 'b"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1205 |
(@{const_name is_rbt}, SOME @{typ "('a :: linorder, 'b) rbt \<Rightarrow> bool"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1206 |
(@{const_name rbt_ins}, SOME @{typ "('a\<Colon>linorder \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1207 |
(@{const_name rbt_insert_with_key}, SOME @{typ "('a\<Colon>linorder \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1208 |
(@{const_name rbt_insert_with}, SOME @{typ "('b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> ('a :: linorder) \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1209 |
(@{const_name rbt_insert}, SOME @{typ "('a :: linorder) \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1210 |
(@{const_name rbt_del_from_left}, SOME @{typ "('a\<Colon>linorder) \<Rightarrow> ('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1211 |
(@{const_name rbt_del_from_right}, SOME @{typ "('a\<Colon>linorder) \<Rightarrow> ('a,'b) rbt \<Rightarrow> 'a \<Rightarrow> 'b \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1212 |
(@{const_name rbt_del}, SOME @{typ "('a\<Colon>linorder) \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1213 |
(@{const_name rbt_delete}, SOME @{typ "('a\<Colon>linorder) \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1214 |
(@{const_name rbt_union_with_key}, SOME @{typ "('a\<Colon>linorder \<Rightarrow> 'b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1215 |
(@{const_name rbt_union_with}, SOME @{typ "('b \<Rightarrow> 'b \<Rightarrow> 'b) \<Rightarrow> ('a\<Colon>linorder,'b) rbt \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1216 |
(@{const_name rbt_union}, SOME @{typ "('a\<Colon>linorder,'b) rbt \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1217 |
(@{const_name rbt_map_entry}, SOME @{typ "'a\<Colon>linorder \<Rightarrow> ('b \<Rightarrow> 'b) \<Rightarrow> ('a,'b) rbt \<Rightarrow> ('a,'b) rbt"}), |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1218 |
(@{const_name rbt_bulkload}, SOME @{typ "('a \<times> 'b) list \<Rightarrow> ('a\<Colon>linorder,'b) rbt"})] |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1219 |
*} |
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1220 |
|
2ada2be850cb
move RBT implementation into type class contexts
Andreas Lochbihler
parents:
47397
diff
changeset
|
1221 |
hide_const (open) R B Empty entries keys map fold |
26192
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1222 |
|
52617dca8386
new theory of red-black trees, an efficient implementation of finite maps.
krauss
parents:
diff
changeset
|
1223 |
end |