| author | wenzelm | 
| Thu, 29 Oct 2009 17:58:26 +0100 | |
| changeset 33317 | b4534348b8fd | 
| parent 31076 | 99fe356cbbc2 | 
| child 36452 | d37c6eed8117 | 
| permissions | -rw-r--r-- | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 1 | (* Title: HOLCF/Adm.thy | 
| 25895 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 2 | Author: Franz Regensburger and Brian Huffman | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 3 | *) | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 4 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 5 | header {* Admissibility and compactness *}
 | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 6 | |
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 7 | theory Adm | 
| 27181 | 8 | imports Cont | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 9 | begin | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 10 | |
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 11 | defaultsort cpo | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 12 | |
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 13 | subsection {* Definitions *}
 | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 14 | |
| 25131 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
19440diff
changeset | 15 | definition | 
| 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
19440diff
changeset | 16 |   adm :: "('a::cpo \<Rightarrow> bool) \<Rightarrow> bool" where
 | 
| 
2c8caac48ade
modernized specifications ('definition', 'abbreviation', 'notation');
 wenzelm parents: 
19440diff
changeset | 17 | "adm P = (\<forall>Y. chain Y \<longrightarrow> (\<forall>i. P (Y i)) \<longrightarrow> P (\<Squnion>i. Y i))" | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 18 | |
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 19 | lemma admI: | 
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 20 | "(\<And>Y. \<lbrakk>chain Y; \<forall>i. P (Y i)\<rbrakk> \<Longrightarrow> P (\<Squnion>i. Y i)) \<Longrightarrow> adm P" | 
| 25895 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 21 | unfolding adm_def by fast | 
| 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 22 | |
| 25925 | 23 | lemma admD: "\<lbrakk>adm P; chain Y; \<And>i. P (Y i)\<rbrakk> \<Longrightarrow> P (\<Squnion>i. Y i)" | 
| 25895 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 24 | unfolding adm_def by fast | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 25 | |
| 27181 | 26 | lemma admD2: "\<lbrakk>adm (\<lambda>x. \<not> P x); chain Y; P (\<Squnion>i. Y i)\<rbrakk> \<Longrightarrow> \<exists>i. P (Y i)" | 
| 27 | unfolding adm_def by fast | |
| 28 | ||
| 16565 | 29 | lemma triv_admI: "\<forall>x. P x \<Longrightarrow> adm P" | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 30 | by (rule admI, erule spec) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 31 | |
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 32 | text {* improved admissibility introduction *}
 | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 33 | |
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 34 | lemma admI2: | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 35 | "(\<And>Y. \<lbrakk>chain Y; \<forall>i. P (Y i); \<forall>i. \<exists>j>i. Y i \<noteq> Y j \<and> Y i \<sqsubseteq> Y j\<rbrakk> | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 36 | \<Longrightarrow> P (\<Squnion>i. Y i)) \<Longrightarrow> adm P" | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 37 | apply (rule admI) | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 38 | apply (erule (1) increasing_chain_adm_lemma) | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 39 | apply fast | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 40 | done | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 41 | |
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 42 | subsection {* Admissibility on chain-finite types *}
 | 
| 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 43 | |
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 44 | text {* for chain-finite (easy) types every formula is admissible *}
 | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 45 | |
| 25921 | 46 | lemma adm_chfin: "adm (P::'a::chfin \<Rightarrow> bool)" | 
| 47 | by (rule admI, frule chfin, auto simp add: maxinch_is_thelub) | |
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 48 | |
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 49 | subsection {* Admissibility of special formulae and propagation *}
 | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 50 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 51 | lemma adm_not_free: "adm (\<lambda>x. t)" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 52 | by (rule admI, simp) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 53 | |
| 16565 | 54 | lemma adm_conj: "\<lbrakk>adm P; adm Q\<rbrakk> \<Longrightarrow> adm (\<lambda>x. P x \<and> Q x)" | 
| 25925 | 55 | by (fast intro: admI elim: admD) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 56 | |
| 27290 | 57 | lemma adm_all: "(\<And>y. adm (\<lambda>x. P x y)) \<Longrightarrow> adm (\<lambda>x. \<forall>y. P x y)" | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 58 | by (fast intro: admI elim: admD) | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 59 | |
| 27290 | 60 | lemma adm_ball: "(\<And>y. y \<in> A \<Longrightarrow> adm (\<lambda>x. P x y)) \<Longrightarrow> adm (\<lambda>x. \<forall>y\<in>A. P x y)" | 
| 17586 | 61 | by (fast intro: admI elim: admD) | 
| 62 | ||
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 63 | text {* Admissibility for disjunction is hard to prove. It takes 5 Lemmas *}
 | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 64 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 65 | lemma adm_disj_lemma1: | 
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 66 | "\<lbrakk>chain (Y::nat \<Rightarrow> 'a::cpo); \<forall>i. \<exists>j\<ge>i. P (Y j)\<rbrakk> | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 67 | \<Longrightarrow> chain (\<lambda>i. Y (LEAST j. i \<le> j \<and> P (Y j)))" | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 68 | apply (rule chainI) | 
| 25922 
cb04d05e95fb
rename lemma chain_mono3 -> chain_mono, chain_mono -> chain_mono_less
 huffman parents: 
25921diff
changeset | 69 | apply (erule chain_mono) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 70 | apply (rule Least_le) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 71 | apply (rule LeastI2_ex) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 72 | apply simp_all | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 73 | done | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 74 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 75 | lemmas adm_disj_lemma2 = LeastI_ex [of "\<lambda>j. i \<le> j \<and> P (Y j)", standard] | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 76 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 77 | lemma adm_disj_lemma3: | 
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 78 | "\<lbrakk>chain (Y::nat \<Rightarrow> 'a::cpo); \<forall>i. \<exists>j\<ge>i. P (Y j)\<rbrakk> \<Longrightarrow> | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 79 | (\<Squnion>i. Y i) = (\<Squnion>i. Y (LEAST j. i \<le> j \<and> P (Y j)))" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 80 | apply (frule (1) adm_disj_lemma1) | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 81 | apply (rule below_antisym) | 
| 25923 | 82 | apply (rule lub_mono, assumption+) | 
| 25922 
cb04d05e95fb
rename lemma chain_mono3 -> chain_mono, chain_mono -> chain_mono_less
 huffman parents: 
25921diff
changeset | 83 | apply (erule chain_mono) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 84 | apply (simp add: adm_disj_lemma2) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 85 | apply (rule lub_range_mono, fast, assumption+) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 86 | done | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 87 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 88 | lemma adm_disj_lemma4: | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 89 | "\<lbrakk>adm P; chain Y; \<forall>i. \<exists>j\<ge>i. P (Y j)\<rbrakk> \<Longrightarrow> P (\<Squnion>i. Y i)" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 90 | apply (subst adm_disj_lemma3, assumption+) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 91 | apply (erule admD) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 92 | apply (simp add: adm_disj_lemma1) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 93 | apply (simp add: adm_disj_lemma2) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 94 | done | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 95 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 96 | lemma adm_disj_lemma5: | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 97 | "\<forall>n::nat. P n \<or> Q n \<Longrightarrow> (\<forall>i. \<exists>j\<ge>i. P j) \<or> (\<forall>i. \<exists>j\<ge>i. Q j)" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 98 | apply (erule contrapos_pp) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 99 | apply (clarsimp, rename_tac a b) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 100 | apply (rule_tac x="max a b" in exI) | 
| 25895 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 101 | apply simp | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 102 | done | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 103 | |
| 16623 
f3fcfa388ecb
cleaned up; added adm_less to adm_lemmas; added subsection headings
 huffman parents: 
16565diff
changeset | 104 | lemma adm_disj: "\<lbrakk>adm P; adm Q\<rbrakk> \<Longrightarrow> adm (\<lambda>x. P x \<or> Q x)" | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 105 | apply (rule admI) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 106 | apply (erule adm_disj_lemma5 [THEN disjE]) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 107 | apply (erule (2) adm_disj_lemma4 [THEN disjI1]) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 108 | apply (erule (2) adm_disj_lemma4 [THEN disjI2]) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 109 | done | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 110 | |
| 16565 | 111 | lemma adm_imp: "\<lbrakk>adm (\<lambda>x. \<not> P x); adm Q\<rbrakk> \<Longrightarrow> adm (\<lambda>x. P x \<longrightarrow> Q x)" | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 112 | by (subst imp_conv_disj, rule adm_disj) | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 113 | |
| 16565 | 114 | lemma adm_iff: | 
| 115 | "\<lbrakk>adm (\<lambda>x. P x \<longrightarrow> Q x); adm (\<lambda>x. Q x \<longrightarrow> P x)\<rbrakk> | |
| 116 | \<Longrightarrow> adm (\<lambda>x. P x = Q x)" | |
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 117 | by (subst iff_conv_conj_imp, rule adm_conj) | 
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 118 | |
| 16565 | 119 | lemma adm_not_conj: | 
| 120 | "\<lbrakk>adm (\<lambda>x. \<not> P x); adm (\<lambda>x. \<not> Q x)\<rbrakk> \<Longrightarrow> adm (\<lambda>x. \<not> (P x \<and> Q x))" | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 121 | by (simp add: adm_imp) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 122 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 123 | text {* admissibility and continuity *}
 | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 124 | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 125 | lemma adm_below: "\<lbrakk>cont u; cont v\<rbrakk> \<Longrightarrow> adm (\<lambda>x. u x \<sqsubseteq> v x)" | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 126 | apply (rule admI) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 127 | apply (simp add: cont2contlubE) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 128 | apply (rule lub_mono) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 129 | apply (erule (1) ch2ch_cont) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 130 | apply (erule (1) ch2ch_cont) | 
| 25923 | 131 | apply (erule spec) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 132 | done | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 133 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 134 | lemma adm_eq: "\<lbrakk>cont u; cont v\<rbrakk> \<Longrightarrow> adm (\<lambda>x. u x = v x)" | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 135 | by (simp add: po_eq_conv adm_conj adm_below) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 136 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 137 | lemma adm_subst: "\<lbrakk>cont t; adm P\<rbrakk> \<Longrightarrow> adm (\<lambda>x. P (t x))" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 138 | apply (rule admI) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 139 | apply (simp add: cont2contlubE) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 140 | apply (erule admD) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 141 | apply (erule (1) ch2ch_cont) | 
| 25925 | 142 | apply (erule spec) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 143 | done | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 144 | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 145 | lemma adm_not_below: "cont t \<Longrightarrow> adm (\<lambda>x. \<not> t x \<sqsubseteq> u)" | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 146 | apply (rule admI) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 147 | apply (drule_tac x=0 in spec) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 148 | apply (erule contrapos_nn) | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 149 | apply (erule rev_below_trans) | 
| 25786 | 150 | apply (erule cont2mono [THEN monofunE]) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 151 | apply (erule is_ub_thelub) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 152 | done | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 153 | |
| 25880 | 154 | subsection {* Compactness *}
 | 
| 155 | ||
| 156 | definition | |
| 157 | compact :: "'a::cpo \<Rightarrow> bool" where | |
| 158 | "compact k = adm (\<lambda>x. \<not> k \<sqsubseteq> x)" | |
| 159 | ||
| 160 | lemma compactI: "adm (\<lambda>x. \<not> k \<sqsubseteq> x) \<Longrightarrow> compact k" | |
| 161 | unfolding compact_def . | |
| 162 | ||
| 163 | lemma compactD: "compact k \<Longrightarrow> adm (\<lambda>x. \<not> k \<sqsubseteq> x)" | |
| 164 | unfolding compact_def . | |
| 165 | ||
| 166 | lemma compactI2: | |
| 27413 | 167 | "(\<And>Y. \<lbrakk>chain Y; x \<sqsubseteq> (\<Squnion>i. Y i)\<rbrakk> \<Longrightarrow> \<exists>i. x \<sqsubseteq> Y i) \<Longrightarrow> compact x" | 
| 25880 | 168 | unfolding compact_def adm_def by fast | 
| 169 | ||
| 170 | lemma compactD2: | |
| 27413 | 171 | "\<lbrakk>compact x; chain Y; x \<sqsubseteq> (\<Squnion>i. Y i)\<rbrakk> \<Longrightarrow> \<exists>i. x \<sqsubseteq> Y i" | 
| 25880 | 172 | unfolding compact_def adm_def by fast | 
| 173 | ||
| 174 | lemma compact_chfin [simp]: "compact (x::'a::chfin)" | |
| 175 | by (rule compactI [OF adm_chfin]) | |
| 176 | ||
| 177 | lemma compact_imp_max_in_chain: | |
| 178 | "\<lbrakk>chain Y; compact (\<Squnion>i. Y i)\<rbrakk> \<Longrightarrow> \<exists>i. max_in_chain i Y" | |
| 179 | apply (drule (1) compactD2, simp) | |
| 180 | apply (erule exE, rule_tac x=i in exI) | |
| 181 | apply (rule max_in_chainI) | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 182 | apply (rule below_antisym) | 
| 25922 
cb04d05e95fb
rename lemma chain_mono3 -> chain_mono, chain_mono -> chain_mono_less
 huffman parents: 
25921diff
changeset | 183 | apply (erule (1) chain_mono) | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 184 | apply (erule (1) below_trans [OF is_ub_thelub]) | 
| 25880 | 185 | done | 
| 186 | ||
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 187 | text {* admissibility and compactness *}
 | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 188 | |
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 189 | lemma adm_compact_not_below: "\<lbrakk>compact k; cont t\<rbrakk> \<Longrightarrow> adm (\<lambda>x. \<not> k \<sqsubseteq> t x)" | 
| 25880 | 190 | unfolding compact_def by (rule adm_subst) | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 191 | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 192 | lemma adm_neq_compact: "\<lbrakk>compact k; cont t\<rbrakk> \<Longrightarrow> adm (\<lambda>x. t x \<noteq> k)" | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 193 | by (simp add: po_eq_conv adm_imp adm_not_below adm_compact_not_below) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 194 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 195 | lemma adm_compact_neq: "\<lbrakk>compact k; cont t\<rbrakk> \<Longrightarrow> adm (\<lambda>x. k \<noteq> t x)" | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 196 | by (simp add: po_eq_conv adm_imp adm_not_below adm_compact_not_below) | 
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 197 | |
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 198 | lemma compact_UU [simp, intro]: "compact \<bottom>" | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 199 | by (rule compactI, simp add: adm_not_free) | 
| 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 200 | |
| 19440 | 201 | lemma adm_not_UU: "cont t \<Longrightarrow> adm (\<lambda>x. t x \<noteq> \<bottom>)" | 
| 202 | by (simp add: adm_neq_compact) | |
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 203 | |
| 25802 | 204 | text {* Any upward-closed predicate is admissible. *}
 | 
| 205 | ||
| 206 | lemma adm_upward: | |
| 207 | assumes P: "\<And>x y. \<lbrakk>P x; x \<sqsubseteq> y\<rbrakk> \<Longrightarrow> P y" | |
| 208 | shows "adm P" | |
| 209 | by (rule admI, drule spec, erule P, erule is_ub_thelub) | |
| 210 | ||
| 17814 
21183d6f62b8
added notion of compactness; shortened proof of adm_disj; reorganized and cleaned up
 huffman parents: 
17586diff
changeset | 211 | lemmas adm_lemmas [simp] = | 
| 25895 
0eaadfa8889e
converted adm_all and adm_ball to rule_format; cleaned up
 huffman parents: 
25880diff
changeset | 212 | adm_not_free adm_conj adm_all adm_ball adm_disj adm_imp adm_iff | 
| 31076 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 213 | adm_below adm_eq adm_not_below | 
| 
99fe356cbbc2
rename constant sq_le to below; rename class sq_ord to below; less->below in many lemma names
 huffman parents: 
29138diff
changeset | 214 | adm_compact_not_below adm_compact_neq adm_neq_compact adm_not_UU | 
| 16056 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 215 | |
| 
32c3b7188c28
Moved admissibility definitions and lemmas to a separate theory
 huffman parents: diff
changeset | 216 | end |