| author | wenzelm | 
| Tue, 31 Oct 2017 18:56:24 +0100 | |
| changeset 66965 | 9cec50354099 | 
| parent 66838 | 17989f6bc7b2 | 
| child 67091 | 1393c2340eec | 
| permissions | -rw-r--r-- | 
| 31596 | 1 | (* Author: Florian Haftmann, TU Muenchen *) | 
| 26348 | 2 | |
| 60758 | 3 | section \<open>Finite types as explicit enumerations\<close> | 
| 26348 | 4 | |
| 5 | theory Enum | |
| 58101 | 6 | imports Map Groups_List | 
| 26348 | 7 | begin | 
| 8 | ||
| 61799 | 9 | subsection \<open>Class \<open>enum\<close>\<close> | 
| 26348 | 10 | |
| 29797 | 11 | class enum = | 
| 26348 | 12 | fixes enum :: "'a list" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 13 |   fixes enum_all :: "('a \<Rightarrow> bool) \<Rightarrow> bool"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 14 |   fixes enum_ex :: "('a \<Rightarrow> bool) \<Rightarrow> bool"
 | 
| 33635 | 15 | assumes UNIV_enum: "UNIV = set enum" | 
| 26444 | 16 | and enum_distinct: "distinct enum" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 17 | assumes enum_all_UNIV: "enum_all P \<longleftrightarrow> Ball UNIV P" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 18 | assumes enum_ex_UNIV: "enum_ex P \<longleftrightarrow> Bex UNIV P" | 
| 61799 | 19 | \<comment> \<open>tailored towards simple instantiation\<close> | 
| 26348 | 20 | begin | 
| 21 | ||
| 29797 | 22 | subclass finite proof | 
| 23 | qed (simp add: UNIV_enum) | |
| 26444 | 24 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 25 | lemma enum_UNIV: | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 26 | "set enum = UNIV" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 27 | by (simp only: UNIV_enum) | 
| 26444 | 28 | |
| 40683 | 29 | lemma in_enum: "x \<in> set enum" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 30 | by (simp add: enum_UNIV) | 
| 26348 | 31 | |
| 32 | lemma enum_eq_I: | |
| 33 | assumes "\<And>x. x \<in> set xs" | |
| 34 | shows "set enum = set xs" | |
| 35 | proof - | |
| 36 | from assms UNIV_eq_I have "UNIV = set xs" by auto | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 37 | with enum_UNIV show ?thesis by simp | 
| 26348 | 38 | qed | 
| 39 | ||
| 49972 
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
 haftmann parents: 
49950diff
changeset | 40 | lemma card_UNIV_length_enum: | 
| 
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
 haftmann parents: 
49950diff
changeset | 41 | "card (UNIV :: 'a set) = length enum" | 
| 
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
 haftmann parents: 
49950diff
changeset | 42 | by (simp add: UNIV_enum distinct_card enum_distinct) | 
| 
f11f8905d9fd
incorporated constant chars into instantiation proof for enum;
 haftmann parents: 
49950diff
changeset | 43 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 44 | lemma enum_all [simp]: | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 45 | "enum_all = HOL.All" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 46 | by (simp add: fun_eq_iff enum_all_UNIV) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 47 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 48 | lemma enum_ex [simp]: | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 49 | "enum_ex = HOL.Ex" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 50 | by (simp add: fun_eq_iff enum_ex_UNIV) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 51 | |
| 26348 | 52 | end | 
| 53 | ||
| 54 | ||
| 60758 | 55 | subsection \<open>Implementations using @{class enum}\<close>
 | 
| 49949 | 56 | |
| 60758 | 57 | subsubsection \<open>Unbounded operations and quantifiers\<close> | 
| 49949 | 58 | |
| 59 | lemma Collect_code [code]: | |
| 60 | "Collect P = set (filter P enum)" | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 61 | by (simp add: enum_UNIV) | 
| 49949 | 62 | |
| 50567 
768a3fbe4149
providing a custom code equation for vimage to overwrite the vimage definition that would be rewritten by set_comprehension_pointfree simproc in the code preprocessor to an non-terminating code equation
 bulwahn parents: 
49972diff
changeset | 63 | lemma vimage_code [code]: | 
| 
768a3fbe4149
providing a custom code equation for vimage to overwrite the vimage definition that would be rewritten by set_comprehension_pointfree simproc in the code preprocessor to an non-terminating code equation
 bulwahn parents: 
49972diff
changeset | 64 | "f -` B = set (filter (%x. f x : B) enum_class.enum)" | 
| 
768a3fbe4149
providing a custom code equation for vimage to overwrite the vimage definition that would be rewritten by set_comprehension_pointfree simproc in the code preprocessor to an non-terminating code equation
 bulwahn parents: 
49972diff
changeset | 65 | unfolding vimage_def Collect_code .. | 
| 
768a3fbe4149
providing a custom code equation for vimage to overwrite the vimage definition that would be rewritten by set_comprehension_pointfree simproc in the code preprocessor to an non-terminating code equation
 bulwahn parents: 
49972diff
changeset | 66 | |
| 49949 | 67 | definition card_UNIV :: "'a itself \<Rightarrow> nat" | 
| 68 | where | |
| 69 |   [code del]: "card_UNIV TYPE('a) = card (UNIV :: 'a set)"
 | |
| 70 | ||
| 71 | lemma [code]: | |
| 72 |   "card_UNIV TYPE('a :: enum) = card (set (Enum.enum :: 'a list))"
 | |
| 73 | by (simp only: card_UNIV_def enum_UNIV) | |
| 74 | ||
| 75 | lemma all_code [code]: "(\<forall>x. P x) \<longleftrightarrow> enum_all P" | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 76 | by simp | 
| 49949 | 77 | |
| 78 | lemma exists_code [code]: "(\<exists>x. P x) \<longleftrightarrow> enum_ex P" | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 79 | by simp | 
| 49949 | 80 | |
| 81 | lemma exists1_code [code]: "(\<exists>!x. P x) \<longleftrightarrow> list_ex1 P enum" | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 82 | by (auto simp add: list_ex1_iff enum_UNIV) | 
| 49949 | 83 | |
| 84 | ||
| 60758 | 85 | subsubsection \<open>An executable choice operator\<close> | 
| 49949 | 86 | |
| 87 | definition | |
| 88 | [code del]: "enum_the = The" | |
| 89 | ||
| 90 | lemma [code]: | |
| 91 | "The P = (case filter P enum of [x] => x | _ => enum_the P)" | |
| 92 | proof - | |
| 93 |   {
 | |
| 94 | fix a | |
| 95 | assume filter_enum: "filter P enum = [a]" | |
| 96 | have "The P = a" | |
| 97 | proof (rule the_equality) | |
| 98 | fix x | |
| 99 | assume "P x" | |
| 100 | show "x = a" | |
| 101 | proof (rule ccontr) | |
| 102 | assume "x \<noteq> a" | |
| 103 | from filter_enum obtain us vs | |
| 104 | where enum_eq: "enum = us @ [a] @ vs" | |
| 105 | and "\<forall> x \<in> set us. \<not> P x" | |
| 106 | and "\<forall> x \<in> set vs. \<not> P x" | |
| 107 | and "P a" | |
| 108 | by (auto simp add: filter_eq_Cons_iff) (simp only: filter_empty_conv[symmetric]) | |
| 60758 | 109 | with \<open>P x\<close> in_enum[of x, unfolded enum_eq] \<open>x \<noteq> a\<close> show "False" by auto | 
| 49949 | 110 | qed | 
| 111 | next | |
| 112 | from filter_enum show "P a" by (auto simp add: filter_eq_Cons_iff) | |
| 113 | qed | |
| 114 | } | |
| 115 | from this show ?thesis | |
| 116 | unfolding enum_the_def by (auto split: list.split) | |
| 117 | qed | |
| 118 | ||
| 54890 
cb892d835803
fundamental treatment of undefined vs. universally partial replaces code_abort
 haftmann parents: 
54295diff
changeset | 119 | declare [[code abort: enum_the]] | 
| 52435 
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
 haftmann parents: 
50567diff
changeset | 120 | |
| 
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
 haftmann parents: 
50567diff
changeset | 121 | code_printing | 
| 
6646bb548c6b
migration from code_(const|type|class|instance) to code_printing and from code_module to code_identifier
 haftmann parents: 
50567diff
changeset | 122 | constant enum_the \<rightharpoonup> (Eval) "(fn '_ => raise Match)" | 
| 49949 | 123 | |
| 124 | ||
| 60758 | 125 | subsubsection \<open>Equality and order on functions\<close> | 
| 26348 | 126 | |
| 38857 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 127 | instantiation "fun" :: (enum, equal) equal | 
| 26513 | 128 | begin | 
| 26348 | 129 | |
| 26513 | 130 | definition | 
| 38857 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 131 | "HOL.equal f g \<longleftrightarrow> (\<forall>x \<in> set enum. f x = g x)" | 
| 26513 | 132 | |
| 31464 | 133 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 134 | qed (simp_all add: equal_fun_def fun_eq_iff enum_UNIV) | 
| 26513 | 135 | |
| 136 | end | |
| 26348 | 137 | |
| 40898 
882e860a1e83
changed order of lemmas to overwrite the general code equation with the nbe-specific one
 bulwahn parents: 
40683diff
changeset | 138 | lemma [code]: | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 139 | "HOL.equal f g \<longleftrightarrow> enum_all (%x. f x = g x)" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 140 | by (auto simp add: equal fun_eq_iff) | 
| 40898 
882e860a1e83
changed order of lemmas to overwrite the general code equation with the nbe-specific one
 bulwahn parents: 
40683diff
changeset | 141 | |
| 38857 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 142 | lemma [code nbe]: | 
| 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 143 | "HOL.equal (f :: _ \<Rightarrow> _) f \<longleftrightarrow> True" | 
| 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 144 | by (fact equal_refl) | 
| 
97775f3e8722
renamed class/constant eq to equal; tuned some instantiations
 haftmann parents: 
37765diff
changeset | 145 | |
| 28562 | 146 | lemma order_fun [code]: | 
| 61076 | 147 | fixes f g :: "'a::enum \<Rightarrow> 'b::order" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 148 | shows "f \<le> g \<longleftrightarrow> enum_all (\<lambda>x. f x \<le> g x)" | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 149 | and "f < g \<longleftrightarrow> f \<le> g \<and> enum_ex (\<lambda>x. f x \<noteq> g x)" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 150 | by (simp_all add: fun_eq_iff le_fun_def order_less_le) | 
| 26968 | 151 | |
| 152 | ||
| 60758 | 153 | subsubsection \<open>Operations on relations\<close> | 
| 49949 | 154 | |
| 155 | lemma [code]: | |
| 156 | "Id = image (\<lambda>x. (x, x)) (set Enum.enum)" | |
| 157 | by (auto intro: imageI in_enum) | |
| 26968 | 158 | |
| 54148 | 159 | lemma tranclp_unfold [code]: | 
| 49949 | 160 |   "tranclp r a b \<longleftrightarrow> (a, b) \<in> trancl {(x, y). r x y}"
 | 
| 161 | by (simp add: trancl_def) | |
| 162 | ||
| 54148 | 163 | lemma rtranclp_rtrancl_eq [code]: | 
| 49949 | 164 |   "rtranclp r x y \<longleftrightarrow> (x, y) \<in> rtrancl {(x, y). r x y}"
 | 
| 165 | by (simp add: rtrancl_def) | |
| 26968 | 166 | |
| 49949 | 167 | lemma max_ext_eq [code]: | 
| 168 |   "max_ext R = {(X, Y). finite X \<and> finite Y \<and> Y \<noteq> {} \<and> (\<forall>x. x \<in> X \<longrightarrow> (\<exists>xa \<in> Y. (x, xa) \<in> R))}"
 | |
| 169 | by (auto simp add: max_ext.simps) | |
| 170 | ||
| 171 | lemma max_extp_eq [code]: | |
| 172 |   "max_extp r x y \<longleftrightarrow> (x, y) \<in> max_ext {(x, y). r x y}"
 | |
| 173 | by (simp add: max_ext_def) | |
| 26348 | 174 | |
| 49949 | 175 | lemma mlex_eq [code]: | 
| 176 |   "f <*mlex*> R = {(x, y). f x < f y \<or> (f x \<le> f y \<and> (x, y) \<in> R)}"
 | |
| 177 | by (auto simp add: mlex_prod_def) | |
| 178 | ||
| 55088 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 179 | |
| 60758 | 180 | subsubsection \<open>Bounded accessible part\<close> | 
| 55088 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 181 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 182 | primrec bacc :: "('a \<times> 'a) set \<Rightarrow> nat \<Rightarrow> 'a set" 
 | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 183 | where | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 184 |   "bacc r 0 = {x. \<forall> y. (y, x) \<notin> r}"
 | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 185 | | "bacc r (Suc n) = (bacc r n \<union> {x. \<forall>y. (y, x) \<in> r \<longrightarrow> y \<in> bacc r n})"
 | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 186 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 187 | lemma bacc_subseteq_acc: | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 188 | "bacc r n \<subseteq> Wellfounded.acc r" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 189 | by (induct n) (auto intro: acc.intros) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 190 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 191 | lemma bacc_mono: | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 192 | "n \<le> m \<Longrightarrow> bacc r n \<subseteq> bacc r m" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 193 | by (induct rule: dec_induct) auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 194 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 195 | lemma bacc_upper_bound: | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 196 |   "bacc (r :: ('a \<times> 'a) set)  (card (UNIV :: 'a::finite set)) = (\<Union>n. bacc r n)"
 | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 197 | proof - | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 198 | have "mono (bacc r)" unfolding mono_def by (simp add: bacc_mono) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 199 | moreover have "\<forall>n. bacc r n = bacc r (Suc n) \<longrightarrow> bacc r (Suc n) = bacc r (Suc (Suc n))" by auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 200 | moreover have "finite (range (bacc r))" by auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 201 | ultimately show ?thesis | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 202 | by (intro finite_mono_strict_prefix_implies_finite_fixpoint) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 203 | (auto intro: finite_mono_remains_stable_implies_strict_prefix) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 204 | qed | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 205 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 206 | lemma acc_subseteq_bacc: | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 207 | assumes "finite r" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 208 | shows "Wellfounded.acc r \<subseteq> (\<Union>n. bacc r n)" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 209 | proof | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 210 | fix x | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 211 | assume "x : Wellfounded.acc r" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 212 | then have "\<exists> n. x : bacc r n" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 213 | proof (induct x arbitrary: rule: acc.induct) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 214 | case (accI x) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 215 | then have "\<forall>y. \<exists> n. (y, x) \<in> r --> y : bacc r n" by simp | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 216 | from choice[OF this] obtain n where n: "\<forall>y. (y, x) \<in> r \<longrightarrow> y \<in> bacc r (n y)" .. | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 217 | obtain n where "\<And>y. (y, x) : r \<Longrightarrow> y : bacc r n" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 218 | proof | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 219 | fix y assume y: "(y, x) : r" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 220 | with n have "y : bacc r (n y)" by auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 221 | moreover have "n y <= Max ((%(y, x). n y) ` r)" | 
| 60758 | 222 | using y \<open>finite r\<close> by (auto intro!: Max_ge) | 
| 55088 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 223 | note bacc_mono[OF this, of r] | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 224 | ultimately show "y : bacc r (Max ((%(y, x). n y) ` r))" by auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 225 | qed | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 226 | then show ?case | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 227 | by (auto simp add: Let_def intro!: exI[of _ "Suc n"]) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 228 | qed | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 229 | then show "x : (UN n. bacc r n)" by auto | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 230 | qed | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 231 | |
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 232 | lemma acc_bacc_eq: | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 233 |   fixes A :: "('a :: finite \<times> 'a) set"
 | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 234 | assumes "finite A" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 235 | shows "Wellfounded.acc A = bacc A (card (UNIV :: 'a set))" | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 236 | using assms by (metis acc_subseteq_bacc bacc_subseteq_acc bacc_upper_bound order_eq_iff) | 
| 
57c82e01022b
moved 'bacc' back to 'Enum' (cf. 744934b818c7) -- reduces baggage loaded by 'Hilbert_Choice'
 blanchet parents: 
54890diff
changeset | 237 | |
| 49949 | 238 | lemma [code]: | 
| 239 |   fixes xs :: "('a::finite \<times> 'a) list"
 | |
| 54295 | 240 |   shows "Wellfounded.acc (set xs) = bacc (set xs) (card_UNIV TYPE('a))"
 | 
| 49949 | 241 | by (simp add: card_UNIV_def acc_bacc_eq) | 
| 242 | ||
| 26348 | 243 | |
| 60758 | 244 | subsection \<open>Default instances for @{class enum}\<close>
 | 
| 26348 | 245 | |
| 26444 | 246 | lemma map_of_zip_enum_is_Some: | 
| 61076 | 247 | assumes "length ys = length (enum :: 'a::enum list)" | 
| 248 | shows "\<exists>y. map_of (zip (enum :: 'a::enum list) ys) x = Some y" | |
| 26444 | 249 | proof - | 
| 61076 | 250 | from assms have "x \<in> set (enum :: 'a::enum list) \<longleftrightarrow> | 
| 251 | (\<exists>y. map_of (zip (enum :: 'a::enum list) ys) x = Some y)" | |
| 26444 | 252 | by (auto intro!: map_of_zip_is_Some) | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 253 | then show ?thesis using enum_UNIV by auto | 
| 26444 | 254 | qed | 
| 255 | ||
| 256 | lemma map_of_zip_enum_inject: | |
| 61076 | 257 | fixes xs ys :: "'b::enum list" | 
| 258 | assumes length: "length xs = length (enum :: 'a::enum list)" | |
| 259 | "length ys = length (enum :: 'a::enum list)" | |
| 260 | and map_of: "the \<circ> map_of (zip (enum :: 'a::enum list) xs) = the \<circ> map_of (zip (enum :: 'a::enum list) ys)" | |
| 26444 | 261 | shows "xs = ys" | 
| 262 | proof - | |
| 61076 | 263 | have "map_of (zip (enum :: 'a list) xs) = map_of (zip (enum :: 'a list) ys)" | 
| 26444 | 264 | proof | 
| 265 | fix x :: 'a | |
| 266 | from length map_of_zip_enum_is_Some obtain y1 y2 | |
| 61076 | 267 | where "map_of (zip (enum :: 'a list) xs) x = Some y1" | 
| 268 | and "map_of (zip (enum :: 'a list) ys) x = Some y2" by blast | |
| 47230 | 269 | moreover from map_of | 
| 61076 | 270 | have "the (map_of (zip (enum :: 'a::enum list) xs) x) = the (map_of (zip (enum :: 'a::enum list) ys) x)" | 
| 26444 | 271 | by (auto dest: fun_cong) | 
| 61076 | 272 | ultimately show "map_of (zip (enum :: 'a::enum list) xs) x = map_of (zip (enum :: 'a::enum list) ys) x" | 
| 26444 | 273 | by simp | 
| 274 | qed | |
| 275 | with length enum_distinct show "xs = ys" by (rule map_of_zip_inject) | |
| 276 | qed | |
| 277 | ||
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 278 | definition all_n_lists :: "(('a :: enum) list \<Rightarrow> bool) \<Rightarrow> nat \<Rightarrow> bool"
 | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 279 | where | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 280 | "all_n_lists P n \<longleftrightarrow> (\<forall>xs \<in> set (List.n_lists n enum). P xs)" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 281 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 282 | lemma [code]: | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 283 | "all_n_lists P n \<longleftrightarrow> (if n = 0 then P [] else enum_all (%x. all_n_lists (%xs. P (x # xs)) (n - 1)))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 284 | unfolding all_n_lists_def enum_all | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 285 | by (cases n) (auto simp add: enum_UNIV) | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 286 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 287 | definition ex_n_lists :: "(('a :: enum) list \<Rightarrow> bool) \<Rightarrow> nat \<Rightarrow> bool"
 | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 288 | where | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 289 | "ex_n_lists P n \<longleftrightarrow> (\<exists>xs \<in> set (List.n_lists n enum). P xs)" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 290 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 291 | lemma [code]: | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 292 | "ex_n_lists P n \<longleftrightarrow> (if n = 0 then P [] else enum_ex (%x. ex_n_lists (%xs. P (x # xs)) (n - 1)))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 293 | unfolding ex_n_lists_def enum_ex | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 294 | by (cases n) (auto simp add: enum_UNIV) | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 295 | |
| 26444 | 296 | instantiation "fun" :: (enum, enum) enum | 
| 297 | begin | |
| 298 | ||
| 299 | definition | |
| 61076 | 300 | "enum = map (\<lambda>ys. the o map_of (zip (enum::'a list) ys)) (List.n_lists (length (enum::'a::enum list)) enum)" | 
| 26444 | 301 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 302 | definition | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 303 | "enum_all P = all_n_lists (\<lambda>bs. P (the o map_of (zip enum bs))) (length (enum :: 'a list))" | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 304 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 305 | definition | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 306 | "enum_ex P = ex_n_lists (\<lambda>bs. P (the o map_of (zip enum bs))) (length (enum :: 'a list))" | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 307 | |
| 26444 | 308 | instance proof | 
| 61076 | 309 |   show "UNIV = set (enum :: ('a \<Rightarrow> 'b) list)"
 | 
| 26444 | 310 | proof (rule UNIV_eq_I) | 
| 311 | fix f :: "'a \<Rightarrow> 'b" | |
| 61076 | 312 | have "f = the \<circ> map_of (zip (enum :: 'a::enum list) (map f enum))" | 
| 40683 | 313 | by (auto simp add: map_of_zip_map fun_eq_iff intro: in_enum) | 
| 26444 | 314 | then show "f \<in> set enum" | 
| 40683 | 315 | by (auto simp add: enum_fun_def set_n_lists intro: in_enum) | 
| 26444 | 316 | qed | 
| 317 | next | |
| 318 | from map_of_zip_enum_inject | |
| 61076 | 319 |   show "distinct (enum :: ('a \<Rightarrow> 'b) list)"
 | 
| 26444 | 320 | by (auto intro!: inj_onI simp add: enum_fun_def | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 321 | distinct_map distinct_n_lists enum_distinct set_n_lists) | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 322 | next | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 323 | fix P | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 324 |   show "enum_all (P :: ('a \<Rightarrow> 'b) \<Rightarrow> bool) = Ball UNIV P"
 | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 325 | proof | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 326 | assume "enum_all P" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 327 | show "Ball UNIV P" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 328 | proof | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 329 | fix f :: "'a \<Rightarrow> 'b" | 
| 61076 | 330 | have f: "f = the \<circ> map_of (zip (enum :: 'a::enum list) (map f enum))" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 331 | by (auto simp add: map_of_zip_map fun_eq_iff intro: in_enum) | 
| 60758 | 332 | from \<open>enum_all P\<close> have "P (the \<circ> map_of (zip enum (map f enum)))" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 333 | unfolding enum_all_fun_def all_n_lists_def | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 334 | apply (simp add: set_n_lists) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 335 | apply (erule_tac x="map f enum" in allE) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 336 | apply (auto intro!: in_enum) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 337 | done | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 338 | from this f show "P f" by auto | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 339 | qed | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 340 | next | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 341 | assume "Ball UNIV P" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 342 | from this show "enum_all P" | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 343 | unfolding enum_all_fun_def all_n_lists_def by auto | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 344 | qed | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 345 | next | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 346 | fix P | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 347 |   show "enum_ex (P :: ('a \<Rightarrow> 'b) \<Rightarrow> bool) = Bex UNIV P"
 | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 348 | proof | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 349 | assume "enum_ex P" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 350 | from this show "Bex UNIV P" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 351 | unfolding enum_ex_fun_def ex_n_lists_def by auto | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 352 | next | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 353 | assume "Bex UNIV P" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 354 | from this obtain f where "P f" .. | 
| 61076 | 355 | have f: "f = the \<circ> map_of (zip (enum :: 'a::enum list) (map f enum))" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 356 | by (auto simp add: map_of_zip_map fun_eq_iff intro: in_enum) | 
| 61076 | 357 | from \<open>P f\<close> this have "P (the \<circ> map_of (zip (enum :: 'a::enum list) (map f enum)))" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 358 | by auto | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 359 | from this show "enum_ex P" | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 360 | unfolding enum_ex_fun_def ex_n_lists_def | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 361 | apply (auto simp add: set_n_lists) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 362 | apply (rule_tac x="map f enum" in exI) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 363 | apply (auto intro!: in_enum) | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 364 | done | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 365 | qed | 
| 26444 | 366 | qed | 
| 367 | ||
| 368 | end | |
| 369 | ||
| 61076 | 370 | lemma enum_fun_code [code]: "enum = (let enum_a = (enum :: 'a::{enum, equal} list)
 | 
| 49948 
744934b818c7
moved quite generic material from theory Enum to more appropriate places
 haftmann parents: 
48123diff
changeset | 371 | in map (\<lambda>ys. the o map_of (zip enum_a ys)) (List.n_lists (length enum_a) enum))" | 
| 28245 
9767dd8e1e54
celver code lemma avoid type ambiguity problem with Haskell
 haftmann parents: 
27487diff
changeset | 372 | by (simp add: enum_fun_def Let_def) | 
| 26444 | 373 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 374 | lemma enum_all_fun_code [code]: | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 375 |   "enum_all P = (let enum_a = (enum :: 'a::{enum, equal} list)
 | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 376 | in all_n_lists (\<lambda>bs. P (the o map_of (zip enum_a bs))) (length enum_a))" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 377 | by (simp only: enum_all_fun_def Let_def) | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 378 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 379 | lemma enum_ex_fun_code [code]: | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 380 |   "enum_ex P = (let enum_a = (enum :: 'a::{enum, equal} list)
 | 
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 381 | in ex_n_lists (\<lambda>bs. P (the o map_of (zip enum_a bs))) (length enum_a))" | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 382 | by (simp only: enum_ex_fun_def Let_def) | 
| 45963 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 383 | |
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 384 | instantiation set :: (enum) enum | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 385 | begin | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 386 | |
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 387 | definition | 
| 65956 
639eb3617a86
reorganised material on sublists
 eberlm <eberlm@in.tum.de> parents: 
64592diff
changeset | 388 | "enum = map set (subseqs enum)" | 
| 45963 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 389 | |
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 390 | definition | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 391 | "enum_all P \<longleftrightarrow> (\<forall>A\<in>set enum. P (A::'a set))" | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 392 | |
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 393 | definition | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 394 | "enum_ex P \<longleftrightarrow> (\<exists>A\<in>set enum. P (A::'a set))" | 
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 395 | |
| 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 396 | instance proof | 
| 65956 
639eb3617a86
reorganised material on sublists
 eberlm <eberlm@in.tum.de> parents: 
64592diff
changeset | 397 | qed (simp_all add: enum_set_def enum_all_set_def enum_ex_set_def subseqs_powset distinct_set_subseqs | 
| 45963 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 398 | enum_distinct enum_UNIV) | 
| 29024 | 399 | |
| 400 | end | |
| 401 | ||
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 402 | instantiation unit :: enum | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 403 | begin | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 404 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 405 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 406 | "enum = [()]" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 407 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 408 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 409 | "enum_all P = P ()" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 410 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 411 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 412 | "enum_ex P = P ()" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 413 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 414 | instance proof | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 415 | qed (auto simp add: enum_unit_def enum_all_unit_def enum_ex_unit_def) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 416 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 417 | end | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 418 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 419 | instantiation bool :: enum | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 420 | begin | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 421 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 422 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 423 | "enum = [False, True]" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 424 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 425 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 426 | "enum_all P \<longleftrightarrow> P False \<and> P True" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 427 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 428 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 429 | "enum_ex P \<longleftrightarrow> P False \<or> P True" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 430 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 431 | instance proof | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 432 | qed (simp_all only: enum_bool_def enum_all_bool_def enum_ex_bool_def UNIV_bool, simp_all) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 433 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 434 | end | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 435 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 436 | instantiation prod :: (enum, enum) enum | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 437 | begin | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 438 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 439 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 440 | "enum = List.product enum enum" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 441 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 442 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 443 | "enum_all P = enum_all (%x. enum_all (%y. P (x, y)))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 444 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 445 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 446 | "enum_ex P = enum_ex (%x. enum_ex (%y. P (x, y)))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 447 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 448 | |
| 61169 | 449 | instance | 
| 450 | by standard | |
| 451 | (simp_all add: enum_prod_def distinct_product | |
| 452 | enum_UNIV enum_distinct enum_all_prod_def enum_ex_prod_def) | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 453 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 454 | end | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 455 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 456 | instantiation sum :: (enum, enum) enum | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 457 | begin | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 458 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 459 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 460 | "enum = map Inl enum @ map Inr enum" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 461 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 462 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 463 | "enum_all P \<longleftrightarrow> enum_all (\<lambda>x. P (Inl x)) \<and> enum_all (\<lambda>x. P (Inr x))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 464 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 465 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 466 | "enum_ex P \<longleftrightarrow> enum_ex (\<lambda>x. P (Inl x)) \<or> enum_ex (\<lambda>x. P (Inr x))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 467 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 468 | instance proof | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 469 | qed (simp_all only: enum_sum_def enum_all_sum_def enum_ex_sum_def UNIV_sum, | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 470 | auto simp add: enum_UNIV distinct_map enum_distinct) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 471 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 472 | end | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 473 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 474 | instantiation option :: (enum) enum | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 475 | begin | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 476 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 477 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 478 | "enum = None # map Some enum" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 479 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 480 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 481 | "enum_all P \<longleftrightarrow> P None \<and> enum_all (\<lambda>x. P (Some x))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 482 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 483 | definition | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 484 | "enum_ex P \<longleftrightarrow> P None \<or> enum_ex (\<lambda>x. P (Some x))" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 485 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 486 | instance proof | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 487 | qed (simp_all only: enum_option_def enum_all_option_def enum_ex_option_def UNIV_option_conv, | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 488 | auto simp add: distinct_map enum_UNIV enum_distinct) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 489 | |
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 490 | end | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 491 | |
| 45963 
1c7e6454883e
enum type class instance for `set`; dropped misfitting code lemma for trancl
 haftmann parents: 
45144diff
changeset | 492 | |
| 60758 | 493 | subsection \<open>Small finite types\<close> | 
| 40647 | 494 | |
| 60758 | 495 | text \<open>We define small finite types for use in Quickcheck\<close> | 
| 40647 | 496 | |
| 58659 
6c9821c32dd5
Local_Interpretation is superseded by Plugin with formal Plugin_Name management, avoiding undeclared strings;
 wenzelm parents: 
58646diff
changeset | 497 | datatype (plugins only: code "quickcheck" extraction) finite_1 = | 
| 58350 
919149921e46
added 'extraction' plugins -- this might help 'HOL-Proofs'
 blanchet parents: 
58334diff
changeset | 498 | a\<^sub>1 | 
| 40647 | 499 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 500 | notation (output) a\<^sub>1  ("a\<^sub>1")
 | 
| 40900 
1d5f76d79856
adding shorter output syntax for the finite types of quickcheck
 bulwahn parents: 
40898diff
changeset | 501 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 502 | lemma UNIV_finite_1: | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 503 |   "UNIV = {a\<^sub>1}"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 504 | by (auto intro: finite_1.exhaust) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 505 | |
| 40647 | 506 | instantiation finite_1 :: enum | 
| 507 | begin | |
| 508 | ||
| 509 | definition | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 510 | "enum = [a\<^sub>1]" | 
| 40647 | 511 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 512 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 513 | "enum_all P = P a\<^sub>1" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 514 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 515 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 516 | "enum_ex P = P a\<^sub>1" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 517 | |
| 40647 | 518 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 519 | qed (simp_all only: enum_finite_1_def enum_all_finite_1_def enum_ex_finite_1_def UNIV_finite_1, simp_all) | 
| 40647 | 520 | |
| 29024 | 521 | end | 
| 40647 | 522 | |
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 523 | instantiation finite_1 :: linorder | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 524 | begin | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 525 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 526 | definition less_finite_1 :: "finite_1 \<Rightarrow> finite_1 \<Rightarrow> bool" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 527 | where | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 528 | "x < (y :: finite_1) \<longleftrightarrow> False" | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 529 | |
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 530 | definition less_eq_finite_1 :: "finite_1 \<Rightarrow> finite_1 \<Rightarrow> bool" | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 531 | where | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 532 | "x \<le> (y :: finite_1) \<longleftrightarrow> True" | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 533 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 534 | instance | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 535 | apply (intro_classes) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 536 | apply (auto simp add: less_finite_1_def less_eq_finite_1_def) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 537 | apply (metis finite_1.exhaust) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 538 | done | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 539 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 540 | end | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 541 | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 542 | instance finite_1 :: "{dense_linorder, wellorder}"
 | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 543 | by intro_classes (simp_all add: less_finite_1_def) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 544 | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 545 | instantiation finite_1 :: complete_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 546 | begin | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 547 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 548 | definition [simp]: "Inf = (\<lambda>_. a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 549 | definition [simp]: "Sup = (\<lambda>_. a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 550 | definition [simp]: "bot = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 551 | definition [simp]: "top = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 552 | definition [simp]: "inf = (\<lambda>_ _. a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 553 | definition [simp]: "sup = (\<lambda>_ _. a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 554 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 555 | instance by intro_classes(simp_all add: less_eq_finite_1_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 556 | end | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 557 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 558 | instance finite_1 :: complete_distrib_lattice | 
| 62343 
24106dc44def
prefer abbreviations for compound operators INFIMUM and SUPREMUM
 haftmann parents: 
61799diff
changeset | 559 | by standard simp_all | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 560 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 561 | instance finite_1 :: complete_linorder .. | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 562 | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 563 | lemma finite_1_eq: "x = a\<^sub>1" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 564 | by(cases x) simp | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 565 | |
| 60758 | 566 | simproc_setup finite_1_eq ("x::finite_1") = \<open>
 | 
| 59582 | 567 | fn _ => fn _ => fn ct => | 
| 568 | (case Thm.term_of ct of | |
| 569 |       Const (@{const_name a\<^sub>1}, _) => NONE
 | |
| 570 |     | _ => SOME (mk_meta_eq @{thm finite_1_eq}))
 | |
| 60758 | 571 | \<close> | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 572 | |
| 59582 | 573 | instantiation finite_1 :: complete_boolean_algebra | 
| 574 | begin | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 575 | definition [simp]: "op - = (\<lambda>_ _. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 576 | definition [simp]: "uminus = (\<lambda>_. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 577 | instance by intro_classes simp_all | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 578 | end | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 579 | |
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 580 | instantiation finite_1 :: | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 581 |   "{linordered_ring_strict, linordered_comm_semiring_strict, ordered_comm_ring,
 | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 582 | ordered_cancel_comm_monoid_diff, comm_monoid_mult, ordered_ring_abs, | 
| 64290 | 583 | one, modulo, sgn, inverse}" | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 584 | begin | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 585 | definition [simp]: "Groups.zero = a\<^sub>1" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 586 | definition [simp]: "Groups.one = a\<^sub>1" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 587 | definition [simp]: "op + = (\<lambda>_ _. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 588 | definition [simp]: "op * = (\<lambda>_ _. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 589 | definition [simp]: "op mod = (\<lambda>_ _. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 590 | definition [simp]: "abs = (\<lambda>_. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 591 | definition [simp]: "sgn = (\<lambda>_. a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 592 | definition [simp]: "inverse = (\<lambda>_. a\<^sub>1)" | 
| 60352 
d46de31a50c4
separate class for division operator, with particular syntax added in more specific classes
 haftmann parents: 
59867diff
changeset | 593 | definition [simp]: "divide = (\<lambda>_ _. a\<^sub>1)" | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 594 | |
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 595 | instance by intro_classes(simp_all add: less_finite_1_def) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 596 | end | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 597 | |
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 598 | declare [[simproc del: finite_1_eq]] | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 599 | hide_const (open) a\<^sub>1 | 
| 40657 | 600 | |
| 58659 
6c9821c32dd5
Local_Interpretation is superseded by Plugin with formal Plugin_Name management, avoiding undeclared strings;
 wenzelm parents: 
58646diff
changeset | 601 | datatype (plugins only: code "quickcheck" extraction) finite_2 = | 
| 58350 
919149921e46
added 'extraction' plugins -- this might help 'HOL-Proofs'
 blanchet parents: 
58334diff
changeset | 602 | a\<^sub>1 | a\<^sub>2 | 
| 40647 | 603 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 604 | notation (output) a\<^sub>1  ("a\<^sub>1")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 605 | notation (output) a\<^sub>2  ("a\<^sub>2")
 | 
| 40900 
1d5f76d79856
adding shorter output syntax for the finite types of quickcheck
 bulwahn parents: 
40898diff
changeset | 606 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 607 | lemma UNIV_finite_2: | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 608 |   "UNIV = {a\<^sub>1, a\<^sub>2}"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 609 | by (auto intro: finite_2.exhaust) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 610 | |
| 40647 | 611 | instantiation finite_2 :: enum | 
| 612 | begin | |
| 613 | ||
| 614 | definition | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 615 | "enum = [a\<^sub>1, a\<^sub>2]" | 
| 40647 | 616 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 617 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 618 | "enum_all P \<longleftrightarrow> P a\<^sub>1 \<and> P a\<^sub>2" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 619 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 620 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 621 | "enum_ex P \<longleftrightarrow> P a\<^sub>1 \<or> P a\<^sub>2" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 622 | |
| 40647 | 623 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 624 | qed (simp_all only: enum_finite_2_def enum_all_finite_2_def enum_ex_finite_2_def UNIV_finite_2, simp_all) | 
| 40647 | 625 | |
| 626 | end | |
| 627 | ||
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 628 | instantiation finite_2 :: linorder | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 629 | begin | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 630 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 631 | definition less_finite_2 :: "finite_2 \<Rightarrow> finite_2 \<Rightarrow> bool" | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 632 | where | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 633 | "x < y \<longleftrightarrow> x = a\<^sub>1 \<and> y = a\<^sub>2" | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 634 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 635 | definition less_eq_finite_2 :: "finite_2 \<Rightarrow> finite_2 \<Rightarrow> bool" | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 636 | where | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 637 | "x \<le> y \<longleftrightarrow> x = y \<or> x < (y :: finite_2)" | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 638 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 639 | instance | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 640 | apply (intro_classes) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 641 | apply (auto simp add: less_finite_2_def less_eq_finite_2_def) | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 642 | apply (metis finite_2.nchotomy)+ | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 643 | done | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 644 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 645 | end | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 646 | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 647 | instance finite_2 :: wellorder | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 648 | by(rule wf_wellorderI)(simp add: less_finite_2_def, intro_classes) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 649 | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 650 | instantiation finite_2 :: complete_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 651 | begin | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 652 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 653 | definition "\<Sqinter>A = (if a\<^sub>1 \<in> A then a\<^sub>1 else a\<^sub>2)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 654 | definition "\<Squnion>A = (if a\<^sub>2 \<in> A then a\<^sub>2 else a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 655 | definition [simp]: "bot = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 656 | definition [simp]: "top = a\<^sub>2" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 657 | definition "x \<sqinter> y = (if x = a\<^sub>1 \<or> y = a\<^sub>1 then a\<^sub>1 else a\<^sub>2)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 658 | definition "x \<squnion> y = (if x = a\<^sub>2 \<or> y = a\<^sub>2 then a\<^sub>2 else a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 659 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 660 | lemma neq_finite_2_a\<^sub>1_iff [simp]: "x \<noteq> a\<^sub>1 \<longleftrightarrow> x = a\<^sub>2" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 661 | by(cases x) simp_all | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 662 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 663 | lemma neq_finite_2_a\<^sub>1_iff' [simp]: "a\<^sub>1 \<noteq> x \<longleftrightarrow> x = a\<^sub>2" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 664 | by(cases x) simp_all | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 665 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 666 | lemma neq_finite_2_a\<^sub>2_iff [simp]: "x \<noteq> a\<^sub>2 \<longleftrightarrow> x = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 667 | by(cases x) simp_all | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 668 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 669 | lemma neq_finite_2_a\<^sub>2_iff' [simp]: "a\<^sub>2 \<noteq> x \<longleftrightarrow> x = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 670 | by(cases x) simp_all | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 671 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 672 | instance | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 673 | proof | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 674 | fix x :: finite_2 and A | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 675 | assume "x \<in> A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 676 | then show "\<Sqinter>A \<le> x" "x \<le> \<Squnion>A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 677 | by(case_tac [!] x)(auto simp add: less_eq_finite_2_def less_finite_2_def Inf_finite_2_def Sup_finite_2_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 678 | qed(auto simp add: less_eq_finite_2_def less_finite_2_def inf_finite_2_def sup_finite_2_def Inf_finite_2_def Sup_finite_2_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 679 | end | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 680 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 681 | instance finite_2 :: complete_distrib_lattice | 
| 62343 
24106dc44def
prefer abbreviations for compound operators INFIMUM and SUPREMUM
 haftmann parents: 
61799diff
changeset | 682 | by standard (auto simp add: sup_finite_2_def inf_finite_2_def Inf_finite_2_def Sup_finite_2_def) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 683 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 684 | instance finite_2 :: complete_linorder .. | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 685 | |
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 686 | instantiation finite_2 :: "{field, idom_abs_sgn, idom_modulo}" begin
 | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 687 | definition [simp]: "0 = a\<^sub>1" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 688 | definition [simp]: "1 = a\<^sub>2" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 689 | definition "x + y = (case (x, y) of (a\<^sub>1, a\<^sub>1) \<Rightarrow> a\<^sub>1 | (a\<^sub>2, a\<^sub>2) \<Rightarrow> a\<^sub>1 | _ \<Rightarrow> a\<^sub>2)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 690 | definition "uminus = (\<lambda>x :: finite_2. x)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 691 | definition "op - = (op + :: finite_2 \<Rightarrow> _)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 692 | definition "x * y = (case (x, y) of (a\<^sub>2, a\<^sub>2) \<Rightarrow> a\<^sub>2 | _ \<Rightarrow> a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 693 | definition "inverse = (\<lambda>x :: finite_2. x)" | 
| 60352 
d46de31a50c4
separate class for division operator, with particular syntax added in more specific classes
 haftmann parents: 
59867diff
changeset | 694 | definition "divide = (op * :: finite_2 \<Rightarrow> _)" | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 695 | definition "x mod y = (case (x, y) of (a\<^sub>2, a\<^sub>1) \<Rightarrow> a\<^sub>2 | _ \<Rightarrow> a\<^sub>1)" | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 696 | definition "abs = (\<lambda>x :: finite_2. x)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 697 | definition "sgn = (\<lambda>x :: finite_2. x)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 698 | instance | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 699 | by standard | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 700 | (simp_all add: plus_finite_2_def uminus_finite_2_def minus_finite_2_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 701 | times_finite_2_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 702 | inverse_finite_2_def divide_finite_2_def modulo_finite_2_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 703 | abs_finite_2_def sgn_finite_2_def | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 704 | split: finite_2.splits) | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 705 | end | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 706 | |
| 58646 
cd63a4b12a33
specialized specification: avoid trivial instances
 haftmann parents: 
58350diff
changeset | 707 | lemma two_finite_2 [simp]: | 
| 
cd63a4b12a33
specialized specification: avoid trivial instances
 haftmann parents: 
58350diff
changeset | 708 | "2 = a\<^sub>1" | 
| 
cd63a4b12a33
specialized specification: avoid trivial instances
 haftmann parents: 
58350diff
changeset | 709 | by (simp add: numeral.simps plus_finite_2_def) | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 710 | |
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 711 | lemma dvd_finite_2_unfold: | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 712 | "x dvd y \<longleftrightarrow> x = a\<^sub>2 \<or> y = a\<^sub>1" | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 713 | by (auto simp add: dvd_def times_finite_2_def split: finite_2.splits) | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 714 | |
| 66817 | 715 | instantiation finite_2 :: "{normalization_semidom, unique_euclidean_semiring}" begin
 | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 716 | definition [simp]: "normalize = (id :: finite_2 \<Rightarrow> _)" | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 717 | definition [simp]: "unit_factor = (id :: finite_2 \<Rightarrow> _)" | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 718 | definition [simp]: "euclidean_size x = (case x of a\<^sub>1 \<Rightarrow> 0 | a\<^sub>2 \<Rightarrow> 1)" | 
| 66838 
17989f6bc7b2
clarified uniqueness criterion for euclidean rings
 haftmann parents: 
66817diff
changeset | 719 | definition [simp]: "division_segment (x :: finite_2) = 1" | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 720 | instance | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 721 | by standard | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 722 | (auto simp add: divide_finite_2_def times_finite_2_def dvd_finite_2_unfold | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 723 | split: finite_2.splits) | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 724 | end | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 725 | |
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 726 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 727 | hide_const (open) a\<^sub>1 a\<^sub>2 | 
| 40657 | 728 | |
| 58659 
6c9821c32dd5
Local_Interpretation is superseded by Plugin with formal Plugin_Name management, avoiding undeclared strings;
 wenzelm parents: 
58646diff
changeset | 729 | datatype (plugins only: code "quickcheck" extraction) finite_3 = | 
| 58350 
919149921e46
added 'extraction' plugins -- this might help 'HOL-Proofs'
 blanchet parents: 
58334diff
changeset | 730 | a\<^sub>1 | a\<^sub>2 | a\<^sub>3 | 
| 40647 | 731 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 732 | notation (output) a\<^sub>1  ("a\<^sub>1")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 733 | notation (output) a\<^sub>2  ("a\<^sub>2")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 734 | notation (output) a\<^sub>3  ("a\<^sub>3")
 | 
| 40900 
1d5f76d79856
adding shorter output syntax for the finite types of quickcheck
 bulwahn parents: 
40898diff
changeset | 735 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 736 | lemma UNIV_finite_3: | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 737 |   "UNIV = {a\<^sub>1, a\<^sub>2, a\<^sub>3}"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 738 | by (auto intro: finite_3.exhaust) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 739 | |
| 40647 | 740 | instantiation finite_3 :: enum | 
| 741 | begin | |
| 742 | ||
| 743 | definition | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 744 | "enum = [a\<^sub>1, a\<^sub>2, a\<^sub>3]" | 
| 40647 | 745 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 746 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 747 | "enum_all P \<longleftrightarrow> P a\<^sub>1 \<and> P a\<^sub>2 \<and> P a\<^sub>3" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 748 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 749 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 750 | "enum_ex P \<longleftrightarrow> P a\<^sub>1 \<or> P a\<^sub>2 \<or> P a\<^sub>3" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 751 | |
| 40647 | 752 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 753 | qed (simp_all only: enum_finite_3_def enum_all_finite_3_def enum_ex_finite_3_def UNIV_finite_3, simp_all) | 
| 40647 | 754 | |
| 755 | end | |
| 756 | ||
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 757 | lemma finite_3_not_eq_unfold: | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 758 |   "x \<noteq> a\<^sub>1 \<longleftrightarrow> x \<in> {a\<^sub>2, a\<^sub>3}"
 | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 759 |   "x \<noteq> a\<^sub>2 \<longleftrightarrow> x \<in> {a\<^sub>1, a\<^sub>3}"
 | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 760 |   "x \<noteq> a\<^sub>3 \<longleftrightarrow> x \<in> {a\<^sub>1, a\<^sub>2}"
 | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 761 | by (cases x; simp)+ | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 762 | |
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 763 | instantiation finite_3 :: linorder | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 764 | begin | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 765 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 766 | definition less_finite_3 :: "finite_3 \<Rightarrow> finite_3 \<Rightarrow> bool" | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 767 | where | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 768 | "x < y = (case x of a\<^sub>1 \<Rightarrow> y \<noteq> a\<^sub>1 | a\<^sub>2 \<Rightarrow> y = a\<^sub>3 | a\<^sub>3 \<Rightarrow> False)" | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 769 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 770 | definition less_eq_finite_3 :: "finite_3 \<Rightarrow> finite_3 \<Rightarrow> bool" | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 771 | where | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 772 | "x \<le> y \<longleftrightarrow> x = y \<or> x < (y :: finite_3)" | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 773 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 774 | instance proof (intro_classes) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 775 | qed (auto simp add: less_finite_3_def less_eq_finite_3_def split: finite_3.split_asm) | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 776 | |
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 777 | end | 
| 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 778 | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 779 | instance finite_3 :: wellorder | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 780 | proof(rule wf_wellorderI) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 781 |   have "inv_image less_than (case_finite_3 0 1 2) = {(x, y). x < y}"
 | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 782 | by(auto simp add: less_finite_3_def split: finite_3.splits) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 783 | from this[symmetric] show "wf \<dots>" by simp | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 784 | qed intro_classes | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 785 | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 786 | instantiation finite_3 :: complete_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 787 | begin | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 788 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 789 | definition "\<Sqinter>A = (if a\<^sub>1 \<in> A then a\<^sub>1 else if a\<^sub>2 \<in> A then a\<^sub>2 else a\<^sub>3)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 790 | definition "\<Squnion>A = (if a\<^sub>3 \<in> A then a\<^sub>3 else if a\<^sub>2 \<in> A then a\<^sub>2 else a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 791 | definition [simp]: "bot = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 792 | definition [simp]: "top = a\<^sub>3" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 793 | definition [simp]: "inf = (min :: finite_3 \<Rightarrow> _)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 794 | definition [simp]: "sup = (max :: finite_3 \<Rightarrow> _)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 795 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 796 | instance | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 797 | proof | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 798 | fix x :: finite_3 and A | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 799 | assume "x \<in> A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 800 | then show "\<Sqinter>A \<le> x" "x \<le> \<Squnion>A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 801 | by(case_tac [!] x)(auto simp add: Inf_finite_3_def Sup_finite_3_def less_eq_finite_3_def less_finite_3_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 802 | next | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 803 | fix A and z :: finite_3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 804 | assume "\<And>x. x \<in> A \<Longrightarrow> z \<le> x" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 805 | then show "z \<le> \<Sqinter>A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 806 | by(cases z)(auto simp add: Inf_finite_3_def less_eq_finite_3_def less_finite_3_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 807 | next | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 808 | fix A and z :: finite_3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 809 | assume *: "\<And>x. x \<in> A \<Longrightarrow> x \<le> z" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 810 | show "\<Squnion>A \<le> z" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 811 | by(auto simp add: Sup_finite_3_def less_eq_finite_3_def less_finite_3_def dest: *) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 812 | qed(auto simp add: Inf_finite_3_def Sup_finite_3_def) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 813 | end | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 814 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 815 | instance finite_3 :: complete_distrib_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 816 | proof | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 817 | fix a :: finite_3 and B | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 818 | show "a \<squnion> \<Sqinter>B = (\<Sqinter>b\<in>B. a \<squnion> b)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 819 | proof(cases a "\<Sqinter>B" rule: finite_3.exhaust[case_product finite_3.exhaust]) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 820 | case a\<^sub>2_a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 821 | then have "\<And>x. x \<in> B \<Longrightarrow> x = a\<^sub>3" | 
| 62390 | 822 | by(case_tac x)(auto simp add: Inf_finite_3_def split: if_split_asm) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 823 | then show ?thesis using a\<^sub>2_a\<^sub>3 | 
| 62390 | 824 | by(auto simp add: Inf_finite_3_def max_def less_eq_finite_3_def less_finite_3_def split: if_split_asm) | 
| 825 | qed (auto simp add: Inf_finite_3_def max_def less_finite_3_def less_eq_finite_3_def split: if_split_asm) | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 826 | show "a \<sqinter> \<Squnion>B = (\<Squnion>b\<in>B. a \<sqinter> b)" | 
| 62343 
24106dc44def
prefer abbreviations for compound operators INFIMUM and SUPREMUM
 haftmann parents: 
61799diff
changeset | 827 | by (cases a "\<Squnion>B" rule: finite_3.exhaust[case_product finite_3.exhaust]) | 
| 62390 | 828 | (auto simp add: Sup_finite_3_def min_def less_finite_3_def less_eq_finite_3_def split: if_split_asm) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 829 | qed | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 830 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 831 | instance finite_3 :: complete_linorder .. | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 832 | |
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 833 | instantiation finite_3 :: "{field, idom_abs_sgn, idom_modulo}" begin
 | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 834 | definition [simp]: "0 = a\<^sub>1" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 835 | definition [simp]: "1 = a\<^sub>2" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 836 | definition | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 837 | "x + y = (case (x, y) of | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 838 | (a\<^sub>1, a\<^sub>1) \<Rightarrow> a\<^sub>1 | (a\<^sub>2, a\<^sub>3) \<Rightarrow> a\<^sub>1 | (a\<^sub>3, a\<^sub>2) \<Rightarrow> a\<^sub>1 | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 839 | | (a\<^sub>1, a\<^sub>2) \<Rightarrow> a\<^sub>2 | (a\<^sub>2, a\<^sub>1) \<Rightarrow> a\<^sub>2 | (a\<^sub>3, a\<^sub>3) \<Rightarrow> a\<^sub>2 | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 840 | | _ \<Rightarrow> a\<^sub>3)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 841 | definition "- x = (case x of a\<^sub>1 \<Rightarrow> a\<^sub>1 | a\<^sub>2 \<Rightarrow> a\<^sub>3 | a\<^sub>3 \<Rightarrow> a\<^sub>2)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 842 | definition "x - y = x + (- y :: finite_3)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 843 | definition "x * y = (case (x, y) of (a\<^sub>2, a\<^sub>2) \<Rightarrow> a\<^sub>2 | (a\<^sub>3, a\<^sub>3) \<Rightarrow> a\<^sub>2 | (a\<^sub>2, a\<^sub>3) \<Rightarrow> a\<^sub>3 | (a\<^sub>3, a\<^sub>2) \<Rightarrow> a\<^sub>3 | _ \<Rightarrow> a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 844 | definition "inverse = (\<lambda>x :: finite_3. x)" | 
| 60429 
d3d1e185cd63
uniform _ div _ as infix syntax for ring division
 haftmann parents: 
60352diff
changeset | 845 | definition "x div y = x * inverse (y :: finite_3)" | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 846 | definition "x mod y = (case y of a\<^sub>1 \<Rightarrow> x | _ \<Rightarrow> a\<^sub>1)" | 
| 64290 | 847 | definition "abs = (\<lambda>x. case x of a\<^sub>3 \<Rightarrow> a\<^sub>2 | _ \<Rightarrow> x)" | 
| 848 | definition "sgn = (\<lambda>x :: finite_3. x)" | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 849 | instance | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 850 | by standard | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 851 | (simp_all add: plus_finite_3_def uminus_finite_3_def minus_finite_3_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 852 | times_finite_3_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 853 | inverse_finite_3_def divide_finite_3_def modulo_finite_3_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 854 | abs_finite_3_def sgn_finite_3_def | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 855 | less_finite_3_def | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 856 | split: finite_3.splits) | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 857 | end | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 858 | |
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 859 | lemma two_finite_3 [simp]: | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 860 | "2 = a\<^sub>3" | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 861 | by (simp add: numeral.simps plus_finite_3_def) | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 862 | |
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 863 | lemma dvd_finite_3_unfold: | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 864 | "x dvd y \<longleftrightarrow> x = a\<^sub>2 \<or> x = a\<^sub>3 \<or> y = a\<^sub>1" | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 865 | by (cases x) (auto simp add: dvd_def times_finite_3_def split: finite_3.splits) | 
| 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 866 | |
| 66817 | 867 | instantiation finite_3 :: "{normalization_semidom, unique_euclidean_semiring}" begin
 | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 868 | definition [simp]: "normalize x = (case x of a\<^sub>3 \<Rightarrow> a\<^sub>2 | _ \<Rightarrow> x)" | 
| 64592 
7759f1766189
more fine-grained type class hierarchy for div and mod
 haftmann parents: 
64290diff
changeset | 869 | definition [simp]: "unit_factor = (id :: finite_3 \<Rightarrow> _)" | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 870 | definition [simp]: "euclidean_size x = (case x of a\<^sub>1 \<Rightarrow> 0 | _ \<Rightarrow> 1)" | 
| 66838 
17989f6bc7b2
clarified uniqueness criterion for euclidean rings
 haftmann parents: 
66817diff
changeset | 871 | definition [simp]: "division_segment (x :: finite_3) = 1" | 
| 66806 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 872 | instance proof | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 873 | fix x :: finite_3 | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 874 | assume "x \<noteq> 0" | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 875 | then show "is_unit (unit_factor x)" | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 876 | by (cases x) (simp_all add: dvd_finite_3_unfold) | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 877 | qed (auto simp add: divide_finite_3_def times_finite_3_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 878 | dvd_finite_3_unfold inverse_finite_3_def plus_finite_3_def | 
| 
a4e82b58d833
abolished (semi)ring_div in favour of euclidean_(semi)ring_cancel
 haftmann parents: 
65956diff
changeset | 879 | split: finite_3.splits) | 
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 880 | end | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 881 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 882 | hide_const (open) a\<^sub>1 a\<^sub>2 a\<^sub>3 | 
| 40657 | 883 | |
| 58659 
6c9821c32dd5
Local_Interpretation is superseded by Plugin with formal Plugin_Name management, avoiding undeclared strings;
 wenzelm parents: 
58646diff
changeset | 884 | datatype (plugins only: code "quickcheck" extraction) finite_4 = | 
| 58350 
919149921e46
added 'extraction' plugins -- this might help 'HOL-Proofs'
 blanchet parents: 
58334diff
changeset | 885 | a\<^sub>1 | a\<^sub>2 | a\<^sub>3 | a\<^sub>4 | 
| 40647 | 886 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 887 | notation (output) a\<^sub>1  ("a\<^sub>1")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 888 | notation (output) a\<^sub>2  ("a\<^sub>2")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 889 | notation (output) a\<^sub>3  ("a\<^sub>3")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 890 | notation (output) a\<^sub>4  ("a\<^sub>4")
 | 
| 40900 
1d5f76d79856
adding shorter output syntax for the finite types of quickcheck
 bulwahn parents: 
40898diff
changeset | 891 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 892 | lemma UNIV_finite_4: | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 893 |   "UNIV = {a\<^sub>1, a\<^sub>2, a\<^sub>3, a\<^sub>4}"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 894 | by (auto intro: finite_4.exhaust) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 895 | |
| 40647 | 896 | instantiation finite_4 :: enum | 
| 897 | begin | |
| 898 | ||
| 899 | definition | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 900 | "enum = [a\<^sub>1, a\<^sub>2, a\<^sub>3, a\<^sub>4]" | 
| 40647 | 901 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 902 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 903 | "enum_all P \<longleftrightarrow> P a\<^sub>1 \<and> P a\<^sub>2 \<and> P a\<^sub>3 \<and> P a\<^sub>4" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 904 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 905 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 906 | "enum_ex P \<longleftrightarrow> P a\<^sub>1 \<or> P a\<^sub>2 \<or> P a\<^sub>3 \<or> P a\<^sub>4" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 907 | |
| 40647 | 908 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 909 | qed (simp_all only: enum_finite_4_def enum_all_finite_4_def enum_ex_finite_4_def UNIV_finite_4, simp_all) | 
| 40647 | 910 | |
| 911 | end | |
| 912 | ||
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 913 | instantiation finite_4 :: complete_lattice begin | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 914 | |
| 60758 | 915 | text \<open>@{term a\<^sub>1} $<$ @{term a\<^sub>2},@{term a\<^sub>3} $<$ @{term a\<^sub>4},
 | 
| 916 |   but @{term a\<^sub>2} and @{term a\<^sub>3} are incomparable.\<close>
 | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 917 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 918 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 919 | "x < y \<longleftrightarrow> (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 920 | (a\<^sub>1, a\<^sub>1) \<Rightarrow> False | (a\<^sub>1, _) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 921 | | (a\<^sub>2, a\<^sub>4) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 922 | | (a\<^sub>3, a\<^sub>4) \<Rightarrow> True | _ \<Rightarrow> False)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 923 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 924 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 925 | "x \<le> y \<longleftrightarrow> (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 926 | (a\<^sub>1, _) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 927 | | (a\<^sub>2, a\<^sub>2) \<Rightarrow> True | (a\<^sub>2, a\<^sub>4) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 928 | | (a\<^sub>3, a\<^sub>3) \<Rightarrow> True | (a\<^sub>3, a\<^sub>4) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 929 | | (a\<^sub>4, a\<^sub>4) \<Rightarrow> True | _ \<Rightarrow> False)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 930 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 931 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 932 | "\<Sqinter>A = (if a\<^sub>1 \<in> A \<or> a\<^sub>2 \<in> A \<and> a\<^sub>3 \<in> A then a\<^sub>1 else if a\<^sub>2 \<in> A then a\<^sub>2 else if a\<^sub>3 \<in> A then a\<^sub>3 else a\<^sub>4)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 933 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 934 | "\<Squnion>A = (if a\<^sub>4 \<in> A \<or> a\<^sub>2 \<in> A \<and> a\<^sub>3 \<in> A then a\<^sub>4 else if a\<^sub>2 \<in> A then a\<^sub>2 else if a\<^sub>3 \<in> A then a\<^sub>3 else a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 935 | definition [simp]: "bot = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 936 | definition [simp]: "top = a\<^sub>4" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 937 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 938 | "x \<sqinter> y = (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 939 | (a\<^sub>1, _) \<Rightarrow> a\<^sub>1 | (_, a\<^sub>1) \<Rightarrow> a\<^sub>1 | (a\<^sub>2, a\<^sub>3) \<Rightarrow> a\<^sub>1 | (a\<^sub>3, a\<^sub>2) \<Rightarrow> a\<^sub>1 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 940 | | (a\<^sub>2, _) \<Rightarrow> a\<^sub>2 | (_, a\<^sub>2) \<Rightarrow> a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 941 | | (a\<^sub>3, _) \<Rightarrow> a\<^sub>3 | (_, a\<^sub>3) \<Rightarrow> a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 942 | | _ \<Rightarrow> a\<^sub>4)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 943 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 944 | "x \<squnion> y = (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 945 | (a\<^sub>4, _) \<Rightarrow> a\<^sub>4 | (_, a\<^sub>4) \<Rightarrow> a\<^sub>4 | (a\<^sub>2, a\<^sub>3) \<Rightarrow> a\<^sub>4 | (a\<^sub>3, a\<^sub>2) \<Rightarrow> a\<^sub>4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 946 | | (a\<^sub>2, _) \<Rightarrow> a\<^sub>2 | (_, a\<^sub>2) \<Rightarrow> a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 947 | | (a\<^sub>3, _) \<Rightarrow> a\<^sub>3 | (_, a\<^sub>3) \<Rightarrow> a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 948 | | _ \<Rightarrow> a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 949 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 950 | instance | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 951 | proof | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 952 | fix A and z :: finite_4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 953 | assume *: "\<And>x. x \<in> A \<Longrightarrow> x \<le> z" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 954 | show "\<Squnion>A \<le> z" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 955 | by(auto simp add: Sup_finite_4_def less_eq_finite_4_def dest!: * split: finite_4.splits) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 956 | next | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 957 | fix A and z :: finite_4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 958 | assume *: "\<And>x. x \<in> A \<Longrightarrow> z \<le> x" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 959 | show "z \<le> \<Sqinter>A" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 960 | by(auto simp add: Inf_finite_4_def less_eq_finite_4_def dest!: * split: finite_4.splits) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 961 | qed(auto simp add: less_finite_4_def less_eq_finite_4_def Inf_finite_4_def Sup_finite_4_def inf_finite_4_def sup_finite_4_def split: finite_4.splits) | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 962 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 963 | end | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 964 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 965 | instance finite_4 :: complete_distrib_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 966 | proof | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 967 | fix a :: finite_4 and B | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 968 | show "a \<squnion> \<Sqinter>B = (\<Sqinter>b\<in>B. a \<squnion> b)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 969 | by(cases a "\<Sqinter>B" rule: finite_4.exhaust[case_product finite_4.exhaust]) | 
| 62390 | 970 | (auto simp add: sup_finite_4_def Inf_finite_4_def split: finite_4.splits if_split_asm) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 971 | show "a \<sqinter> \<Squnion>B = (\<Squnion>b\<in>B. a \<sqinter> b)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 972 | by(cases a "\<Squnion>B" rule: finite_4.exhaust[case_product finite_4.exhaust]) | 
| 62390 | 973 | (auto simp add: inf_finite_4_def Sup_finite_4_def split: finite_4.splits if_split_asm) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 974 | qed | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 975 | |
| 57922 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 976 | instantiation finite_4 :: complete_boolean_algebra begin | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 977 | definition "- x = (case x of a\<^sub>1 \<Rightarrow> a\<^sub>4 | a\<^sub>2 \<Rightarrow> a\<^sub>3 | a\<^sub>3 \<Rightarrow> a\<^sub>2 | a\<^sub>4 \<Rightarrow> a\<^sub>1)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 978 | definition "x - y = x \<sqinter> - (y :: finite_4)" | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 979 | instance | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 980 | by intro_classes | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 981 | (simp_all add: inf_finite_4_def sup_finite_4_def uminus_finite_4_def minus_finite_4_def split: finite_4.splits) | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 982 | end | 
| 
dc78785427d0
add algebraic type class instances for Enum.finite* types
 Andreas Lochbihler parents: 
57818diff
changeset | 983 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 984 | hide_const (open) a\<^sub>1 a\<^sub>2 a\<^sub>3 a\<^sub>4 | 
| 40651 
9752ba7348b5
adding code equation for function equality; adding some instantiations for the finite types
 bulwahn parents: 
40650diff
changeset | 985 | |
| 58659 
6c9821c32dd5
Local_Interpretation is superseded by Plugin with formal Plugin_Name management, avoiding undeclared strings;
 wenzelm parents: 
58646diff
changeset | 986 | datatype (plugins only: code "quickcheck" extraction) finite_5 = | 
| 58350 
919149921e46
added 'extraction' plugins -- this might help 'HOL-Proofs'
 blanchet parents: 
58334diff
changeset | 987 | a\<^sub>1 | a\<^sub>2 | a\<^sub>3 | a\<^sub>4 | a\<^sub>5 | 
| 40647 | 988 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 989 | notation (output) a\<^sub>1  ("a\<^sub>1")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 990 | notation (output) a\<^sub>2  ("a\<^sub>2")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 991 | notation (output) a\<^sub>3  ("a\<^sub>3")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 992 | notation (output) a\<^sub>4  ("a\<^sub>4")
 | 
| 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 993 | notation (output) a\<^sub>5  ("a\<^sub>5")
 | 
| 40900 
1d5f76d79856
adding shorter output syntax for the finite types of quickcheck
 bulwahn parents: 
40898diff
changeset | 994 | |
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 995 | lemma UNIV_finite_5: | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 996 |   "UNIV = {a\<^sub>1, a\<^sub>2, a\<^sub>3, a\<^sub>4, a\<^sub>5}"
 | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 997 | by (auto intro: finite_5.exhaust) | 
| 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 998 | |
| 40647 | 999 | instantiation finite_5 :: enum | 
| 1000 | begin | |
| 1001 | ||
| 1002 | definition | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 1003 | "enum = [a\<^sub>1, a\<^sub>2, a\<^sub>3, a\<^sub>4, a\<^sub>5]" | 
| 40647 | 1004 | |
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 1005 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 1006 | "enum_all P \<longleftrightarrow> P a\<^sub>1 \<and> P a\<^sub>2 \<and> P a\<^sub>3 \<and> P a\<^sub>4 \<and> P a\<^sub>5" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 1007 | |
| 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 1008 | definition | 
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 1009 | "enum_ex P \<longleftrightarrow> P a\<^sub>1 \<or> P a\<^sub>2 \<or> P a\<^sub>3 \<or> P a\<^sub>4 \<or> P a\<^sub>5" | 
| 41078 
051251fde456
adding more efficient implementations for quantifiers in Enum
 bulwahn parents: 
40900diff
changeset | 1010 | |
| 40647 | 1011 | instance proof | 
| 49950 
cd882d53ba6b
tailored enum specification towards simple instantiation;
 haftmann parents: 
49949diff
changeset | 1012 | qed (simp_all only: enum_finite_5_def enum_all_finite_5_def enum_ex_finite_5_def UNIV_finite_5, simp_all) | 
| 40647 | 1013 | |
| 1014 | end | |
| 1015 | ||
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1016 | instantiation finite_5 :: complete_lattice | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1017 | begin | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1018 | |
| 60758 | 1019 | text \<open>The non-distributive pentagon lattice $N_5$\<close> | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1020 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1021 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1022 | "x < y \<longleftrightarrow> (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1023 | (a\<^sub>1, a\<^sub>1) \<Rightarrow> False | (a\<^sub>1, _) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1024 | | (a\<^sub>2, a\<^sub>3) \<Rightarrow> True | (a\<^sub>2, a\<^sub>5) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1025 | | (a\<^sub>3, a\<^sub>5) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1026 | | (a\<^sub>4, a\<^sub>5) \<Rightarrow> True | _ \<Rightarrow> False)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1027 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1028 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1029 | "x \<le> y \<longleftrightarrow> (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1030 | (a\<^sub>1, _) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1031 | | (a\<^sub>2, a\<^sub>2) \<Rightarrow> True | (a\<^sub>2, a\<^sub>3) \<Rightarrow> True | (a\<^sub>2, a\<^sub>5) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1032 | | (a\<^sub>3, a\<^sub>3) \<Rightarrow> True | (a\<^sub>3, a\<^sub>5) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1033 | | (a\<^sub>4, a\<^sub>4) \<Rightarrow> True | (a\<^sub>4, a\<^sub>5) \<Rightarrow> True | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1034 | | (a\<^sub>5, a\<^sub>5) \<Rightarrow> True | _ \<Rightarrow> False)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1035 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1036 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1037 | "\<Sqinter>A = | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1038 | (if a\<^sub>1 \<in> A \<or> a\<^sub>4 \<in> A \<and> (a\<^sub>2 \<in> A \<or> a\<^sub>3 \<in> A) then a\<^sub>1 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1039 | else if a\<^sub>2 \<in> A then a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1040 | else if a\<^sub>3 \<in> A then a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1041 | else if a\<^sub>4 \<in> A then a\<^sub>4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1042 | else a\<^sub>5)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1043 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1044 | "\<Squnion>A = | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1045 | (if a\<^sub>5 \<in> A \<or> a\<^sub>4 \<in> A \<and> (a\<^sub>2 \<in> A \<or> a\<^sub>3 \<in> A) then a\<^sub>5 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1046 | else if a\<^sub>3 \<in> A then a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1047 | else if a\<^sub>2 \<in> A then a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1048 | else if a\<^sub>4 \<in> A then a\<^sub>4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1049 | else a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1050 | definition [simp]: "bot = a\<^sub>1" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1051 | definition [simp]: "top = a\<^sub>5" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1052 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1053 | "x \<sqinter> y = (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1054 | (a\<^sub>1, _) \<Rightarrow> a\<^sub>1 | (_, a\<^sub>1) \<Rightarrow> a\<^sub>1 | (a\<^sub>2, a\<^sub>4) \<Rightarrow> a\<^sub>1 | (a\<^sub>4, a\<^sub>2) \<Rightarrow> a\<^sub>1 | (a\<^sub>3, a\<^sub>4) \<Rightarrow> a\<^sub>1 | (a\<^sub>4, a\<^sub>3) \<Rightarrow> a\<^sub>1 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1055 | | (a\<^sub>2, _) \<Rightarrow> a\<^sub>2 | (_, a\<^sub>2) \<Rightarrow> a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1056 | | (a\<^sub>3, _) \<Rightarrow> a\<^sub>3 | (_, a\<^sub>3) \<Rightarrow> a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1057 | | (a\<^sub>4, _) \<Rightarrow> a\<^sub>4 | (_, a\<^sub>4) \<Rightarrow> a\<^sub>4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1058 | | _ \<Rightarrow> a\<^sub>5)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1059 | definition | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1060 | "x \<squnion> y = (case (x, y) of | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1061 | (a\<^sub>5, _) \<Rightarrow> a\<^sub>5 | (_, a\<^sub>5) \<Rightarrow> a\<^sub>5 | (a\<^sub>2, a\<^sub>4) \<Rightarrow> a\<^sub>5 | (a\<^sub>4, a\<^sub>2) \<Rightarrow> a\<^sub>5 | (a\<^sub>3, a\<^sub>4) \<Rightarrow> a\<^sub>5 | (a\<^sub>4, a\<^sub>3) \<Rightarrow> a\<^sub>5 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1062 | | (a\<^sub>3, _) \<Rightarrow> a\<^sub>3 | (_, a\<^sub>3) \<Rightarrow> a\<^sub>3 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1063 | | (a\<^sub>2, _) \<Rightarrow> a\<^sub>2 | (_, a\<^sub>2) \<Rightarrow> a\<^sub>2 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1064 | | (a\<^sub>4, _) \<Rightarrow> a\<^sub>4 | (_, a\<^sub>4) \<Rightarrow> a\<^sub>4 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1065 | | _ \<Rightarrow> a\<^sub>1)" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1066 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1067 | instance | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1068 | proof intro_classes | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1069 | fix A and z :: finite_5 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1070 | assume *: "\<And>x. x \<in> A \<Longrightarrow> z \<le> x" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1071 | show "z \<le> \<Sqinter>A" | 
| 62390 | 1072 | by(auto simp add: less_eq_finite_5_def Inf_finite_5_def split: finite_5.splits if_split_asm dest!: *) | 
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1073 | next | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1074 | fix A and z :: finite_5 | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1075 | assume *: "\<And>x. x \<in> A \<Longrightarrow> x \<le> z" | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1076 | show "\<Squnion>A \<le> z" | 
| 62390 | 1077 | by(auto simp add: less_eq_finite_5_def Sup_finite_5_def split: finite_5.splits if_split_asm dest!: *) | 
| 1078 | qed(auto simp add: less_eq_finite_5_def less_finite_5_def inf_finite_5_def sup_finite_5_def Inf_finite_5_def Sup_finite_5_def split: finite_5.splits if_split_asm) | |
| 57818 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1079 | |
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1080 | end | 
| 
51aa30c9ee4e
add complete_lattice instances for Enum.finite_* types such that quickcheck deals with lattice class operations
 Andreas Lochbihler parents: 
57247diff
changeset | 1081 | |
| 53015 
a1119cf551e8
standardized symbols via "isabelle update_sub_sup", excluding src/Pure and src/Tools/WWW_Find;
 wenzelm parents: 
52435diff
changeset | 1082 | hide_const (open) a\<^sub>1 a\<^sub>2 a\<^sub>3 a\<^sub>4 a\<^sub>5 | 
| 46352 
73b03235799a
an executable version of accessible part (only for finite types yet)
 bulwahn parents: 
46336diff
changeset | 1083 | |
| 49948 
744934b818c7
moved quite generic material from theory Enum to more appropriate places
 haftmann parents: 
48123diff
changeset | 1084 | |
| 60758 | 1085 | subsection \<open>Closing up\<close> | 
| 40657 | 1086 | |
| 41085 
a549ff1d4070
adding a smarter enumeration scheme for finite functions
 bulwahn parents: 
41078diff
changeset | 1087 | hide_type (open) finite_1 finite_2 finite_3 finite_4 finite_5 | 
| 49948 
744934b818c7
moved quite generic material from theory Enum to more appropriate places
 haftmann parents: 
48123diff
changeset | 1088 | hide_const (open) enum enum_all enum_ex all_n_lists ex_n_lists ntrancl | 
| 40647 | 1089 | |
| 1090 | end |