author | wenzelm |
Wed, 19 Dec 2007 23:06:16 +0100 | |
changeset 25716 | 7a5dcfa5bbe2 |
parent 24893 | b8ef7afe3a6b |
child 27703 | cb6c513922e0 |
permissions | -rw-r--r-- |
1478 | 1 |
(* Title: ZF/Order.thy |
435 | 2 |
ID: $Id$ |
1478 | 3 |
Author: Lawrence C Paulson, Cambridge University Computer Laboratory |
435 | 4 |
Copyright 1994 University of Cambridge |
5 |
||
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
6 |
Results from the book "Set Theory: an Introduction to Independence Proofs" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
7 |
by Kenneth Kunen. Chapter 1, section 6. |
435 | 8 |
*) |
9 |
||
13356 | 10 |
header{*Partial and Total Orderings: Basic Definitions and Properties*} |
11 |
||
16417 | 12 |
theory Order imports WF Perm begin |
786 | 13 |
|
24893 | 14 |
definition |
15 |
part_ord :: "[i,i]=>o" (*Strict partial ordering*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
16 |
"part_ord(A,r) == irrefl(A,r) & trans[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
17 |
|
24893 | 18 |
definition |
19 |
linear :: "[i,i]=>o" (*Strict total ordering*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
20 |
"linear(A,r) == (ALL x:A. ALL y:A. <x,y>:r | x=y | <y,x>:r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
21 |
|
24893 | 22 |
definition |
23 |
tot_ord :: "[i,i]=>o" (*Strict total ordering*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
24 |
"tot_ord(A,r) == part_ord(A,r) & linear(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
25 |
|
24893 | 26 |
definition |
27 |
well_ord :: "[i,i]=>o" (*Well-ordering*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
28 |
"well_ord(A,r) == tot_ord(A,r) & wf[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
29 |
|
24893 | 30 |
definition |
31 |
mono_map :: "[i,i,i,i]=>i" (*Order-preserving maps*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
32 |
"mono_map(A,r,B,s) == |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
33 |
{f: A->B. ALL x:A. ALL y:A. <x,y>:r --> <f`x,f`y>:s}" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
34 |
|
24893 | 35 |
definition |
36 |
ord_iso :: "[i,i,i,i]=>i" (*Order isomorphisms*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
37 |
"ord_iso(A,r,B,s) == |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
38 |
{f: bij(A,B). ALL x:A. ALL y:A. <x,y>:r <-> <f`x,f`y>:s}" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
39 |
|
24893 | 40 |
definition |
41 |
pred :: "[i,i,i]=>i" (*Set of predecessors*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
42 |
"pred(A,x,r) == {y:A. <y,x>:r}" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
43 |
|
24893 | 44 |
definition |
45 |
ord_iso_map :: "[i,i,i,i]=>i" (*Construction for linearity theorem*) where |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
46 |
"ord_iso_map(A,r,B,s) == |
13615
449a70d88b38
Numerous cosmetic changes, prompted by the new simplifier
paulson
parents:
13611
diff
changeset
|
47 |
\<Union>x\<in>A. \<Union>y\<in>B. \<Union>f \<in> ord_iso(pred(A,x,r), r, pred(B,y,s), s). {<x,y>}" |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
48 |
|
24893 | 49 |
definition |
50 |
first :: "[i, i, i] => o" where |
|
2469 | 51 |
"first(u, X, R) == u:X & (ALL v:X. v~=u --> <u,v> : R)" |
52 |
||
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
53 |
|
24893 | 54 |
notation (xsymbols) |
55 |
ord_iso ("(\<langle>_, _\<rangle> \<cong>/ \<langle>_, _\<rangle>)" 51) |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
56 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
57 |
|
13356 | 58 |
subsection{*Immediate Consequences of the Definitions*} |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
59 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
60 |
lemma part_ord_Imp_asym: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
61 |
"part_ord(A,r) ==> asym(r Int A*A)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
62 |
by (unfold part_ord_def irrefl_def trans_on_def asym_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
63 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
64 |
lemma linearE: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
65 |
"[| linear(A,r); x:A; y:A; |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
66 |
<x,y>:r ==> P; x=y ==> P; <y,x>:r ==> P |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
67 |
==> P" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
68 |
by (simp add: linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
69 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
70 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
71 |
(** General properties of well_ord **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
72 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
73 |
lemma well_ordI: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
74 |
"[| wf[A](r); linear(A,r) |] ==> well_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
75 |
apply (simp add: irrefl_def part_ord_def tot_ord_def |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
76 |
trans_on_def well_ord_def wf_on_not_refl) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
77 |
apply (fast elim: linearE wf_on_asym wf_on_chain3) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
78 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
79 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
80 |
lemma well_ord_is_wf: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
81 |
"well_ord(A,r) ==> wf[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
82 |
by (unfold well_ord_def, safe) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
83 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
84 |
lemma well_ord_is_trans_on: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
85 |
"well_ord(A,r) ==> trans[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
86 |
by (unfold well_ord_def tot_ord_def part_ord_def, safe) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
87 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
88 |
lemma well_ord_is_linear: "well_ord(A,r) ==> linear(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
89 |
by (unfold well_ord_def tot_ord_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
90 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
91 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
92 |
(** Derived rules for pred(A,x,r) **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
93 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
94 |
lemma pred_iff: "y : pred(A,x,r) <-> <y,x>:r & y:A" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
95 |
by (unfold pred_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
96 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
97 |
lemmas predI = conjI [THEN pred_iff [THEN iffD2]] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
98 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
99 |
lemma predE: "[| y: pred(A,x,r); [| y:A; <y,x>:r |] ==> P |] ==> P" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
100 |
by (simp add: pred_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
101 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
102 |
lemma pred_subset_under: "pred(A,x,r) <= r -`` {x}" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
103 |
by (simp add: pred_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
104 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
105 |
lemma pred_subset: "pred(A,x,r) <= A" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
106 |
by (simp add: pred_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
107 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
108 |
lemma pred_pred_eq: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
109 |
"pred(pred(A,x,r), y, r) = pred(A,x,r) Int pred(A,y,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
110 |
by (simp add: pred_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
111 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
112 |
lemma trans_pred_pred_eq: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
113 |
"[| trans[A](r); <y,x>:r; x:A; y:A |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
114 |
==> pred(pred(A,x,r), y, r) = pred(A,y,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
115 |
by (unfold trans_on_def pred_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
116 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
117 |
|
13356 | 118 |
subsection{*Restricting an Ordering's Domain*} |
119 |
||
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
120 |
(** The ordering's properties hold over all subsets of its domain |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
121 |
[including initial segments of the form pred(A,x,r) **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
122 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
123 |
(*Note: a relation s such that s<=r need not be a partial ordering*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
124 |
lemma part_ord_subset: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
125 |
"[| part_ord(A,r); B<=A |] ==> part_ord(B,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
126 |
by (unfold part_ord_def irrefl_def trans_on_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
127 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
128 |
lemma linear_subset: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
129 |
"[| linear(A,r); B<=A |] ==> linear(B,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
130 |
by (unfold linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
131 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
132 |
lemma tot_ord_subset: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
133 |
"[| tot_ord(A,r); B<=A |] ==> tot_ord(B,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
134 |
apply (unfold tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
135 |
apply (fast elim!: part_ord_subset linear_subset) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
136 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
137 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
138 |
lemma well_ord_subset: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
139 |
"[| well_ord(A,r); B<=A |] ==> well_ord(B,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
140 |
apply (unfold well_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
141 |
apply (fast elim!: tot_ord_subset wf_on_subset_A) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
142 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
143 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
144 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
145 |
(** Relations restricted to a smaller domain, by Krzysztof Grabczewski **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
146 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
147 |
lemma irrefl_Int_iff: "irrefl(A,r Int A*A) <-> irrefl(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
148 |
by (unfold irrefl_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
149 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
150 |
lemma trans_on_Int_iff: "trans[A](r Int A*A) <-> trans[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
151 |
by (unfold trans_on_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
152 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
153 |
lemma part_ord_Int_iff: "part_ord(A,r Int A*A) <-> part_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
154 |
apply (unfold part_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
155 |
apply (simp add: irrefl_Int_iff trans_on_Int_iff) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
156 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
157 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
158 |
lemma linear_Int_iff: "linear(A,r Int A*A) <-> linear(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
159 |
by (unfold linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
160 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
161 |
lemma tot_ord_Int_iff: "tot_ord(A,r Int A*A) <-> tot_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
162 |
apply (unfold tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
163 |
apply (simp add: part_ord_Int_iff linear_Int_iff) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
164 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
165 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
166 |
lemma wf_on_Int_iff: "wf[A](r Int A*A) <-> wf[A](r)" |
24893 | 167 |
apply (unfold wf_on_def wf_def, fast) (*10 times faster than blast!*) |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
168 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
169 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
170 |
lemma well_ord_Int_iff: "well_ord(A,r Int A*A) <-> well_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
171 |
apply (unfold well_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
172 |
apply (simp add: tot_ord_Int_iff wf_on_Int_iff) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
173 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
174 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
175 |
|
13356 | 176 |
subsection{*Empty and Unit Domains*} |
177 |
||
13701 | 178 |
(*The empty relation is well-founded*) |
179 |
lemma wf_on_any_0: "wf[A](0)" |
|
180 |
by (simp add: wf_on_def wf_def, fast) |
|
181 |
||
182 |
subsubsection{*Relations over the Empty Set*} |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
183 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
184 |
lemma irrefl_0: "irrefl(0,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
185 |
by (unfold irrefl_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
186 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
187 |
lemma trans_on_0: "trans[0](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
188 |
by (unfold trans_on_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
189 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
190 |
lemma part_ord_0: "part_ord(0,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
191 |
apply (unfold part_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
192 |
apply (simp add: irrefl_0 trans_on_0) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
193 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
194 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
195 |
lemma linear_0: "linear(0,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
196 |
by (unfold linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
197 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
198 |
lemma tot_ord_0: "tot_ord(0,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
199 |
apply (unfold tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
200 |
apply (simp add: part_ord_0 linear_0) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
201 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
202 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
203 |
lemma wf_on_0: "wf[0](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
204 |
by (unfold wf_on_def wf_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
205 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
206 |
lemma well_ord_0: "well_ord(0,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
207 |
apply (unfold well_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
208 |
apply (simp add: tot_ord_0 wf_on_0) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
209 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
210 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
211 |
|
13701 | 212 |
subsubsection{*The Empty Relation Well-Orders the Unit Set*} |
213 |
||
214 |
text{*by Grabczewski*} |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
215 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
216 |
lemma tot_ord_unit: "tot_ord({a},0)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
217 |
by (simp add: irrefl_def trans_on_def part_ord_def linear_def tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
218 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
219 |
lemma well_ord_unit: "well_ord({a},0)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
220 |
apply (unfold well_ord_def) |
13701 | 221 |
apply (simp add: tot_ord_unit wf_on_any_0) |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
222 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
223 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
224 |
|
13356 | 225 |
subsection{*Order-Isomorphisms*} |
226 |
||
227 |
text{*Suppes calls them "similarities"*} |
|
228 |
||
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
229 |
(** Order-preserving (monotone) maps **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
230 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
231 |
lemma mono_map_is_fun: "f: mono_map(A,r,B,s) ==> f: A->B" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
232 |
by (simp add: mono_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
233 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
234 |
lemma mono_map_is_inj: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
235 |
"[| linear(A,r); wf[B](s); f: mono_map(A,r,B,s) |] ==> f: inj(A,B)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
236 |
apply (unfold mono_map_def inj_def, clarify) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
237 |
apply (erule_tac x=w and y=x in linearE, assumption+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
238 |
apply (force intro: apply_type dest: wf_on_not_refl)+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
239 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
240 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
241 |
lemma ord_isoI: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
242 |
"[| f: bij(A, B); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
243 |
!!x y. [| x:A; y:A |] ==> <x, y> : r <-> <f`x, f`y> : s |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
244 |
==> f: ord_iso(A,r,B,s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
245 |
by (simp add: ord_iso_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
246 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
247 |
lemma ord_iso_is_mono_map: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
248 |
"f: ord_iso(A,r,B,s) ==> f: mono_map(A,r,B,s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
249 |
apply (simp add: ord_iso_def mono_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
250 |
apply (blast dest!: bij_is_fun) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
251 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
252 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
253 |
lemma ord_iso_is_bij: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
254 |
"f: ord_iso(A,r,B,s) ==> f: bij(A,B)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
255 |
by (simp add: ord_iso_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
256 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
257 |
(*Needed? But ord_iso_converse is!*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
258 |
lemma ord_iso_apply: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
259 |
"[| f: ord_iso(A,r,B,s); <x,y>: r; x:A; y:A |] ==> <f`x, f`y> : s" |
13611 | 260 |
by (simp add: ord_iso_def) |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
261 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
262 |
lemma ord_iso_converse: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
263 |
"[| f: ord_iso(A,r,B,s); <x,y>: s; x:B; y:B |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
264 |
==> <converse(f) ` x, converse(f) ` y> : r" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
265 |
apply (simp add: ord_iso_def, clarify) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
266 |
apply (erule bspec [THEN bspec, THEN iffD2]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
267 |
apply (erule asm_rl bij_converse_bij [THEN bij_is_fun, THEN apply_type])+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
268 |
apply (auto simp add: right_inverse_bij) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
269 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
270 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
271 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
272 |
(** Symmetry and Transitivity Rules **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
273 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
274 |
(*Reflexivity of similarity*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
275 |
lemma ord_iso_refl: "id(A): ord_iso(A,r,A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
276 |
by (rule id_bij [THEN ord_isoI], simp) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
277 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
278 |
(*Symmetry of similarity*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
279 |
lemma ord_iso_sym: "f: ord_iso(A,r,B,s) ==> converse(f): ord_iso(B,s,A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
280 |
apply (simp add: ord_iso_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
281 |
apply (auto simp add: right_inverse_bij bij_converse_bij |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
282 |
bij_is_fun [THEN apply_funtype]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
283 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
284 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
285 |
(*Transitivity of similarity*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
286 |
lemma mono_map_trans: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
287 |
"[| g: mono_map(A,r,B,s); f: mono_map(B,s,C,t) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
288 |
==> (f O g): mono_map(A,r,C,t)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
289 |
apply (unfold mono_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
290 |
apply (auto simp add: comp_fun) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
291 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
292 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
293 |
(*Transitivity of similarity: the order-isomorphism relation*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
294 |
lemma ord_iso_trans: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
295 |
"[| g: ord_iso(A,r,B,s); f: ord_iso(B,s,C,t) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
296 |
==> (f O g): ord_iso(A,r,C,t)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
297 |
apply (unfold ord_iso_def, clarify) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
298 |
apply (frule bij_is_fun [of f]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
299 |
apply (frule bij_is_fun [of g]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
300 |
apply (auto simp add: comp_bij) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
301 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
302 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
303 |
(** Two monotone maps can make an order-isomorphism **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
304 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
305 |
lemma mono_ord_isoI: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
306 |
"[| f: mono_map(A,r,B,s); g: mono_map(B,s,A,r); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
307 |
f O g = id(B); g O f = id(A) |] ==> f: ord_iso(A,r,B,s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
308 |
apply (simp add: ord_iso_def mono_map_def, safe) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
309 |
apply (intro fg_imp_bijective, auto) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
310 |
apply (subgoal_tac "<g` (f`x), g` (f`y) > : r") |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
311 |
apply (simp add: comp_eq_id_iff [THEN iffD1]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
312 |
apply (blast intro: apply_funtype) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
313 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
314 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
315 |
lemma well_ord_mono_ord_isoI: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
316 |
"[| well_ord(A,r); well_ord(B,s); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
317 |
f: mono_map(A,r,B,s); converse(f): mono_map(B,s,A,r) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
318 |
==> f: ord_iso(A,r,B,s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
319 |
apply (intro mono_ord_isoI, auto) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
320 |
apply (frule mono_map_is_fun [THEN fun_is_rel]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
321 |
apply (erule converse_converse [THEN subst], rule left_comp_inverse) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
322 |
apply (blast intro: left_comp_inverse mono_map_is_inj well_ord_is_linear |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
323 |
well_ord_is_wf)+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
324 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
325 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
326 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
327 |
(** Order-isomorphisms preserve the ordering's properties **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
328 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
329 |
lemma part_ord_ord_iso: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
330 |
"[| part_ord(B,s); f: ord_iso(A,r,B,s) |] ==> part_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
331 |
apply (simp add: part_ord_def irrefl_def trans_on_def ord_iso_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
332 |
apply (fast intro: bij_is_fun [THEN apply_type]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
333 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
334 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
335 |
lemma linear_ord_iso: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
336 |
"[| linear(B,s); f: ord_iso(A,r,B,s) |] ==> linear(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
337 |
apply (simp add: linear_def ord_iso_def, safe) |
13339
0f89104dd377
Fixed quantified variable name preservation for ball and bex (bounded quants)
paulson
parents:
13212
diff
changeset
|
338 |
apply (drule_tac x1 = "f`x" and x = "f`y" in bspec [THEN bspec]) |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
339 |
apply (safe elim!: bij_is_fun [THEN apply_type]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
340 |
apply (drule_tac t = "op ` (converse (f))" in subst_context) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
341 |
apply (simp add: left_inverse_bij) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
342 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
343 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
344 |
lemma wf_on_ord_iso: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
345 |
"[| wf[B](s); f: ord_iso(A,r,B,s) |] ==> wf[A](r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
346 |
apply (simp add: wf_on_def wf_def ord_iso_def, safe) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
347 |
apply (drule_tac x = "{f`z. z:Z Int A}" in spec) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
348 |
apply (safe intro!: equalityI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
349 |
apply (blast dest!: equalityD1 intro: bij_is_fun [THEN apply_type])+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
350 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
351 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
352 |
lemma well_ord_ord_iso: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
353 |
"[| well_ord(B,s); f: ord_iso(A,r,B,s) |] ==> well_ord(A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
354 |
apply (unfold well_ord_def tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
355 |
apply (fast elim!: part_ord_ord_iso linear_ord_iso wf_on_ord_iso) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
356 |
done |
9683 | 357 |
|
358 |
||
13356 | 359 |
subsection{*Main results of Kunen, Chapter 1 section 6*} |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
360 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
361 |
(*Inductive argument for Kunen's Lemma 6.1, etc. |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
362 |
Simple proof from Halmos, page 72*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
363 |
lemma well_ord_iso_subset_lemma: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
364 |
"[| well_ord(A,r); f: ord_iso(A,r, A',r); A'<= A; y: A |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
365 |
==> ~ <f`y, y>: r" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
366 |
apply (simp add: well_ord_def ord_iso_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
367 |
apply (elim conjE CollectE) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
368 |
apply (rule_tac a=y in wf_on_induct, assumption+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
369 |
apply (blast dest: bij_is_fun [THEN apply_type]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
370 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
371 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
372 |
(*Kunen's Lemma 6.1: there's no order-isomorphism to an initial segment |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
373 |
of a well-ordering*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
374 |
lemma well_ord_iso_predE: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
375 |
"[| well_ord(A,r); f : ord_iso(A, r, pred(A,x,r), r); x:A |] ==> P" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
376 |
apply (insert well_ord_iso_subset_lemma [of A r f "pred(A,x,r)" x]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
377 |
apply (simp add: pred_subset) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
378 |
(*Now we know f`x < x *) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
379 |
apply (drule ord_iso_is_bij [THEN bij_is_fun, THEN apply_type], assumption) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
380 |
(*Now we also know f`x : pred(A,x,r); contradiction! *) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
381 |
apply (simp add: well_ord_def pred_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
382 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
383 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
384 |
(*Simple consequence of Lemma 6.1*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
385 |
lemma well_ord_iso_pred_eq: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
386 |
"[| well_ord(A,r); f : ord_iso(pred(A,a,r), r, pred(A,c,r), r); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
387 |
a:A; c:A |] ==> a=c" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
388 |
apply (frule well_ord_is_trans_on) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
389 |
apply (frule well_ord_is_linear) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
390 |
apply (erule_tac x=a and y=c in linearE, assumption+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
391 |
apply (drule ord_iso_sym) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
392 |
(*two symmetric cases*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
393 |
apply (auto elim!: well_ord_subset [OF _ pred_subset, THEN well_ord_iso_predE] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
394 |
intro!: predI |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
395 |
simp add: trans_pred_pred_eq) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
396 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
397 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
398 |
(*Does not assume r is a wellordering!*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
399 |
lemma ord_iso_image_pred: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
400 |
"[|f : ord_iso(A,r,B,s); a:A|] ==> f `` pred(A,a,r) = pred(B, f`a, s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
401 |
apply (unfold ord_iso_def pred_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
402 |
apply (erule CollectE) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
403 |
apply (simp (no_asm_simp) add: image_fun [OF bij_is_fun Collect_subset]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
404 |
apply (rule equalityI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
405 |
apply (safe elim!: bij_is_fun [THEN apply_type]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
406 |
apply (rule RepFun_eqI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
407 |
apply (blast intro!: right_inverse_bij [symmetric]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
408 |
apply (auto simp add: right_inverse_bij bij_is_fun [THEN apply_funtype]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
409 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
410 |
|
13212 | 411 |
lemma ord_iso_restrict_image: |
412 |
"[| f : ord_iso(A,r,B,s); C<=A |] |
|
413 |
==> restrict(f,C) : ord_iso(C, r, f``C, s)" |
|
414 |
apply (simp add: ord_iso_def) |
|
415 |
apply (blast intro: bij_is_inj restrict_bij) |
|
416 |
done |
|
417 |
||
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
418 |
(*But in use, A and B may themselves be initial segments. Then use |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
419 |
trans_pred_pred_eq to simplify the pred(pred...) terms. See just below.*) |
13212 | 420 |
lemma ord_iso_restrict_pred: |
421 |
"[| f : ord_iso(A,r,B,s); a:A |] |
|
422 |
==> restrict(f, pred(A,a,r)) : ord_iso(pred(A,a,r), r, pred(B, f`a, s), s)" |
|
423 |
apply (simp add: ord_iso_image_pred [symmetric]) |
|
424 |
apply (blast intro: ord_iso_restrict_image elim: predE) |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
425 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
426 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
427 |
(*Tricky; a lot of forward proof!*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
428 |
lemma well_ord_iso_preserving: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
429 |
"[| well_ord(A,r); well_ord(B,s); <a,c>: r; |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
430 |
f : ord_iso(pred(A,a,r), r, pred(B,b,s), s); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
431 |
g : ord_iso(pred(A,c,r), r, pred(B,d,s), s); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
432 |
a:A; c:A; b:B; d:B |] ==> <b,d>: s" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
433 |
apply (frule ord_iso_is_bij [THEN bij_is_fun, THEN apply_type], (erule asm_rl predI predE)+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
434 |
apply (subgoal_tac "b = g`a") |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
435 |
apply (simp (no_asm_simp)) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
436 |
apply (rule well_ord_iso_pred_eq, auto) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
437 |
apply (frule ord_iso_restrict_pred, (erule asm_rl predI)+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
438 |
apply (simp add: well_ord_is_trans_on trans_pred_pred_eq) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
439 |
apply (erule ord_iso_sym [THEN ord_iso_trans], assumption) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
440 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
441 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
442 |
(*See Halmos, page 72*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
443 |
lemma well_ord_iso_unique_lemma: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
444 |
"[| well_ord(A,r); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
445 |
f: ord_iso(A,r, B,s); g: ord_iso(A,r, B,s); y: A |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
446 |
==> ~ <g`y, f`y> : s" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
447 |
apply (frule well_ord_iso_subset_lemma) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
448 |
apply (rule_tac f = "converse (f) " and g = g in ord_iso_trans) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
449 |
apply auto |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
450 |
apply (blast intro: ord_iso_sym) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
451 |
apply (frule ord_iso_is_bij [of f]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
452 |
apply (frule ord_iso_is_bij [of g]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
453 |
apply (frule ord_iso_converse) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
454 |
apply (blast intro!: bij_converse_bij |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
455 |
intro: bij_is_fun apply_funtype)+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
456 |
apply (erule notE) |
13176
312bd350579b
conversion of Perm to Isar. Strengthening of comp_fun_apply
paulson
parents:
13140
diff
changeset
|
457 |
apply (simp add: left_inverse_bij bij_is_fun comp_fun_apply [of _ A B]) |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
458 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
459 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
460 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
461 |
(*Kunen's Lemma 6.2: Order-isomorphisms between well-orderings are unique*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
462 |
lemma well_ord_iso_unique: "[| well_ord(A,r); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
463 |
f: ord_iso(A,r, B,s); g: ord_iso(A,r, B,s) |] ==> f = g" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
464 |
apply (rule fun_extension) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
465 |
apply (erule ord_iso_is_bij [THEN bij_is_fun])+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
466 |
apply (subgoal_tac "f`x : B & g`x : B & linear(B,s)") |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
467 |
apply (simp add: linear_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
468 |
apply (blast dest: well_ord_iso_unique_lemma) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
469 |
apply (blast intro: ord_iso_is_bij bij_is_fun apply_funtype |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
470 |
well_ord_is_linear well_ord_ord_iso ord_iso_sym) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
471 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
472 |
|
13356 | 473 |
subsection{*Towards Kunen's Theorem 6.3: Linearity of the Similarity Relation*} |
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
474 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
475 |
lemma ord_iso_map_subset: "ord_iso_map(A,r,B,s) <= A*B" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
476 |
by (unfold ord_iso_map_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
477 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
478 |
lemma domain_ord_iso_map: "domain(ord_iso_map(A,r,B,s)) <= A" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
479 |
by (unfold ord_iso_map_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
480 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
481 |
lemma range_ord_iso_map: "range(ord_iso_map(A,r,B,s)) <= B" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
482 |
by (unfold ord_iso_map_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
483 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
484 |
lemma converse_ord_iso_map: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
485 |
"converse(ord_iso_map(A,r,B,s)) = ord_iso_map(B,s,A,r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
486 |
apply (unfold ord_iso_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
487 |
apply (blast intro: ord_iso_sym) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
488 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
489 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
490 |
lemma function_ord_iso_map: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
491 |
"well_ord(B,s) ==> function(ord_iso_map(A,r,B,s))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
492 |
apply (unfold ord_iso_map_def function_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
493 |
apply (blast intro: well_ord_iso_pred_eq ord_iso_sym ord_iso_trans) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
494 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
495 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
496 |
lemma ord_iso_map_fun: "well_ord(B,s) ==> ord_iso_map(A,r,B,s) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
497 |
: domain(ord_iso_map(A,r,B,s)) -> range(ord_iso_map(A,r,B,s))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
498 |
by (simp add: Pi_iff function_ord_iso_map |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
499 |
ord_iso_map_subset [THEN domain_times_range]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
500 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
501 |
lemma ord_iso_map_mono_map: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
502 |
"[| well_ord(A,r); well_ord(B,s) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
503 |
==> ord_iso_map(A,r,B,s) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
504 |
: mono_map(domain(ord_iso_map(A,r,B,s)), r, |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
505 |
range(ord_iso_map(A,r,B,s)), s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
506 |
apply (unfold mono_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
507 |
apply (simp (no_asm_simp) add: ord_iso_map_fun) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
508 |
apply safe |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
509 |
apply (subgoal_tac "x:A & ya:A & y:B & yb:B") |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
510 |
apply (simp add: apply_equality [OF _ ord_iso_map_fun]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
511 |
apply (unfold ord_iso_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
512 |
apply (blast intro: well_ord_iso_preserving, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
513 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
514 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
515 |
lemma ord_iso_map_ord_iso: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
516 |
"[| well_ord(A,r); well_ord(B,s) |] ==> ord_iso_map(A,r,B,s) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
517 |
: ord_iso(domain(ord_iso_map(A,r,B,s)), r, |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
518 |
range(ord_iso_map(A,r,B,s)), s)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
519 |
apply (rule well_ord_mono_ord_isoI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
520 |
prefer 4 |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
521 |
apply (rule converse_ord_iso_map [THEN subst]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
522 |
apply (simp add: ord_iso_map_mono_map |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
523 |
ord_iso_map_subset [THEN converse_converse]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
524 |
apply (blast intro!: domain_ord_iso_map range_ord_iso_map |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
525 |
intro: well_ord_subset ord_iso_map_mono_map)+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
526 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
527 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
528 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
529 |
(*One way of saying that domain(ord_iso_map(A,r,B,s)) is downwards-closed*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
530 |
lemma domain_ord_iso_map_subset: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
531 |
"[| well_ord(A,r); well_ord(B,s); |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
532 |
a: A; a ~: domain(ord_iso_map(A,r,B,s)) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
533 |
==> domain(ord_iso_map(A,r,B,s)) <= pred(A, a, r)" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
534 |
apply (unfold ord_iso_map_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
535 |
apply (safe intro!: predI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
536 |
(*Case analysis on xa vs a in r *) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
537 |
apply (simp (no_asm_simp)) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
538 |
apply (frule_tac A = A in well_ord_is_linear) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
539 |
apply (rename_tac b y f) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
540 |
apply (erule_tac x=b and y=a in linearE, assumption+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
541 |
(*Trivial case: b=a*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
542 |
apply clarify |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
543 |
apply blast |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
544 |
(*Harder case: <a, xa>: r*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
545 |
apply (frule ord_iso_is_bij [THEN bij_is_fun, THEN apply_type], |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
546 |
(erule asm_rl predI predE)+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
547 |
apply (frule ord_iso_restrict_pred) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
548 |
apply (simp add: pred_iff) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
549 |
apply (simp split: split_if_asm |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
550 |
add: well_ord_is_trans_on trans_pred_pred_eq domain_UN domain_Union, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
551 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
552 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
553 |
(*For the 4-way case analysis in the main result*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
554 |
lemma domain_ord_iso_map_cases: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
555 |
"[| well_ord(A,r); well_ord(B,s) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
556 |
==> domain(ord_iso_map(A,r,B,s)) = A | |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
557 |
(EX x:A. domain(ord_iso_map(A,r,B,s)) = pred(A,x,r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
558 |
apply (frule well_ord_is_wf) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
559 |
apply (unfold wf_on_def wf_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
560 |
apply (drule_tac x = "A-domain (ord_iso_map (A,r,B,s))" in spec) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
561 |
apply safe |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
562 |
(*The first case: the domain equals A*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
563 |
apply (rule domain_ord_iso_map [THEN equalityI]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
564 |
apply (erule Diff_eq_0_iff [THEN iffD1]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
565 |
(*The other case: the domain equals an initial segment*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
566 |
apply (blast del: domainI subsetI |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
567 |
elim!: predE |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
568 |
intro!: domain_ord_iso_map_subset |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
569 |
intro: subsetI)+ |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
570 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
571 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
572 |
(*As above, by duality*) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
573 |
lemma range_ord_iso_map_cases: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
574 |
"[| well_ord(A,r); well_ord(B,s) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
575 |
==> range(ord_iso_map(A,r,B,s)) = B | |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
576 |
(EX y:B. range(ord_iso_map(A,r,B,s)) = pred(B,y,s))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
577 |
apply (rule converse_ord_iso_map [THEN subst]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
578 |
apply (simp add: domain_ord_iso_map_cases) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
579 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
580 |
|
13356 | 581 |
text{*Kunen's Theorem 6.3: Fundamental Theorem for Well-Ordered Sets*} |
582 |
theorem well_ord_trichotomy: |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
583 |
"[| well_ord(A,r); well_ord(B,s) |] |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
584 |
==> ord_iso_map(A,r,B,s) : ord_iso(A, r, B, s) | |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
585 |
(EX x:A. ord_iso_map(A,r,B,s) : ord_iso(pred(A,x,r), r, B, s)) | |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
586 |
(EX y:B. ord_iso_map(A,r,B,s) : ord_iso(A, r, pred(B,y,s), s))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
587 |
apply (frule_tac B = B in domain_ord_iso_map_cases, assumption) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
588 |
apply (frule_tac B = B in range_ord_iso_map_cases, assumption) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
589 |
apply (drule ord_iso_map_ord_iso, assumption) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
590 |
apply (elim disjE bexE) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
591 |
apply (simp_all add: bexI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
592 |
apply (rule wf_on_not_refl [THEN notE]) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
593 |
apply (erule well_ord_is_wf) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
594 |
apply assumption |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
595 |
apply (subgoal_tac "<x,y>: ord_iso_map (A,r,B,s) ") |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
596 |
apply (drule rangeI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
597 |
apply (simp add: pred_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
598 |
apply (unfold ord_iso_map_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
599 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
600 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
601 |
|
13356 | 602 |
subsection{*Miscellaneous Results by Krzysztof Grabczewski*} |
603 |
||
604 |
(** Properties of converse(r) **) |
|
13140
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
605 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
606 |
lemma irrefl_converse: "irrefl(A,r) ==> irrefl(A,converse(r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
607 |
by (unfold irrefl_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
608 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
609 |
lemma trans_on_converse: "trans[A](r) ==> trans[A](converse(r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
610 |
by (unfold trans_on_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
611 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
612 |
lemma part_ord_converse: "part_ord(A,r) ==> part_ord(A,converse(r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
613 |
apply (unfold part_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
614 |
apply (blast intro!: irrefl_converse trans_on_converse) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
615 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
616 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
617 |
lemma linear_converse: "linear(A,r) ==> linear(A,converse(r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
618 |
by (unfold linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
619 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
620 |
lemma tot_ord_converse: "tot_ord(A,r) ==> tot_ord(A,converse(r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
621 |
apply (unfold tot_ord_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
622 |
apply (blast intro!: part_ord_converse linear_converse) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
623 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
624 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
625 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
626 |
(** By Krzysztof Grabczewski. |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
627 |
Lemmas involving the first element of a well ordered set **) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
628 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
629 |
lemma first_is_elem: "first(b,B,r) ==> b:B" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
630 |
by (unfold first_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
631 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
632 |
lemma well_ord_imp_ex1_first: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
633 |
"[| well_ord(A,r); B<=A; B~=0 |] ==> (EX! b. first(b,B,r))" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
634 |
apply (unfold well_ord_def wf_on_def wf_def first_def) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
635 |
apply (elim conjE allE disjE, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
636 |
apply (erule bexE) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
637 |
apply (rule_tac a = x in ex1I, auto) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
638 |
apply (unfold tot_ord_def linear_def, blast) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
639 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
640 |
|
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
641 |
lemma the_first_in: |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
642 |
"[| well_ord(A,r); B<=A; B~=0 |] ==> (THE b. first(b,B,r)) : B" |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
643 |
apply (drule well_ord_imp_ex1_first, assumption+) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
644 |
apply (rule first_is_elem) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
645 |
apply (erule theI) |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
646 |
done |
6d97dbb189a9
converted Order.ML OrderType.ML OrderArith.ML to Isar format
paulson
parents:
13119
diff
changeset
|
647 |
|
435 | 648 |
end |