Mercurial > hg > Members > kono > Proof > ZF-in-agda
annotate src/ODUtil.agda @ 1273:30540f151ae0
...
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sun, 02 Apr 2023 12:41:06 +0900 |
parents | 8a071bf52407 |
children | 45cd80181a29 |
rev | line source |
---|---|
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
1 {-# OPTIONS --allow-unsolved-metas #-} |
431 | 2 open import Level |
3 open import Ordinals | |
4 module ODUtil {n : Level } (O : Ordinals {n} ) where | |
5 | |
6 open import zf | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
7 open import Data.Nat renaming ( zero to Zero ; suc to Suc ; ℕ to Nat ; _⊔_ to _n⊔_ ) |
431 | 8 open import Relation.Binary.PropositionalEquality hiding ( [_] ) |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
9 open import Data.Nat.Properties |
431 | 10 open import Data.Empty |
11 open import Relation.Nullary | |
12 open import Relation.Binary hiding ( _⇔_ ) | |
13 | |
14 open import logic | |
15 open import nat | |
16 | |
17 open Ordinals.Ordinals O | |
18 open Ordinals.IsOrdinals isOrdinal | |
19 open Ordinals.IsNext isNext | |
20 import OrdUtil | |
21 open OrdUtil O | |
22 | |
23 import OD | |
24 open OD O | |
25 open OD.OD | |
26 open ODAxiom odAxiom | |
27 | |
28 open HOD | |
29 open _∧_ | |
30 open _==_ | |
31 | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
32 _⊂_ : ( A B : HOD) → Set n |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
33 _⊂_ A B = ( & A o< & B) ∧ ( A ⊆ B ) |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
34 |
1116 | 35 ⊆∩-dist : {a b c : HOD} → a ⊆ b → a ⊆ c → a ⊆ ( b ∩ c ) |
36 ⊆∩-dist {a} {b} {c} a<b a<c {z} az = ⟪ a<b az , a<c az ⟫ | |
37 | |
38 ⊆∩-incl-1 : {a b c : HOD} → a ⊆ c → ( a ∩ b ) ⊆ c | |
39 ⊆∩-incl-1 {a} {b} {c} a<c {z} ab = a<c (proj1 ab) | |
40 | |
41 ⊆∩-incl-2 : {a b c : HOD} → a ⊆ c → ( b ∩ a ) ⊆ c | |
42 ⊆∩-incl-2 {a} {b} {c} a<c {z} ab = a<c (proj2 ab) | |
43 | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
44 cseq : HOD → HOD |
431 | 45 cseq x = record { od = record { def = λ y → odef x (osuc y) } ; odmax = osuc (odmax x) ; <odmax = lemma } where |
46 lemma : {y : Ordinal} → def (od x) (osuc y) → y o< osuc (odmax x) | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
47 lemma {y} lt = ordtrans <-osuc (ordtrans (<odmax x lt) <-osuc ) |
431 | 48 |
1150 | 49 ∩-comm : { A B : HOD } → (A ∩ B) ≡ (B ∩ A) |
50 ∩-comm {A} {B} = ==→o≡ record { eq← = λ {x} lt → ⟪ proj2 lt , proj1 lt ⟫ ; eq→ = λ {x} lt → ⟪ proj2 lt , proj1 lt ⟫ } | |
51 | |
52 _∪_ : ( A B : HOD ) → HOD | |
53 A ∪ B = record { od = record { def = λ x → odef A x ∨ odef B x } ; | |
54 odmax = omax (odmax A) (odmax B) ; <odmax = lemma } where | |
55 lemma : {y : Ordinal} → odef A y ∨ odef B y → y o< omax (odmax A) (odmax B) | |
56 lemma {y} (case1 a) = ordtrans (<odmax A a) (omax-x _ _) | |
57 lemma {y} (case2 b) = ordtrans (<odmax B b) (omax-y _ _) | |
58 | |
1151
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
59 x∪x≡x : { A : HOD } → (A ∪ A) ≡ A |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
60 x∪x≡x {A} = ==→o≡ record { eq← = λ {x} lt → case1 lt ; eq→ = lem00 } where |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
61 lem00 : {x : Ordinal} → odef A x ∨ odef A x → odef A x |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
62 lem00 {x} (case1 ax) = ax |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
63 lem00 {x} (case2 ax) = ax |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
64 |
1150 | 65 _\_ : ( A B : HOD ) → HOD |
66 A \ B = record { od = record { def = λ x → odef A x ∧ ( ¬ ( odef B x ) ) }; odmax = odmax A ; <odmax = λ y → <odmax A (proj1 y) } | |
67 | |
68 ¬∅∋ : {x : HOD} → ¬ ( od∅ ∋ x ) | |
69 ¬∅∋ {x} = ¬x<0 | |
70 | |
431 | 71 |
72 pair-xx<xy : {x y : HOD} → & (x , x) o< osuc (& (x , y) ) | |
73 pair-xx<xy {x} {y} = ⊆→o≤ lemma where | |
74 lemma : {z : Ordinal} → def (od (x , x)) z → def (od (x , y)) z | |
75 lemma {z} (case1 refl) = case1 refl | |
76 lemma {z} (case2 refl) = case1 refl | |
77 | |
78 pair-<xy : {x y : HOD} → {n : Ordinal} → & x o< next n → & y o< next n → & (x , y) o< next n | |
79 pair-<xy {x} {y} {o} x<nn y<nn with trio< (& x) (& y) | inspect (omax (& x)) (& y) | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
80 ... | tri< a ¬b ¬c | record { eq = eq1 } = next< (subst (λ k → k o< next o ) (sym eq1) (osuc<nx y<nn)) ho< |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
81 ... | tri> ¬a ¬b c | record { eq = eq1 } = next< (subst (λ k → k o< next o ) (sym eq1) (osuc<nx x<nn)) ho< |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
82 ... | tri≈ ¬a b ¬c | record { eq = eq1 } = next< (subst (λ k → k o< next o ) (omax≡ _ _ b) (subst (λ k → osuc k o< next o) b (osuc<nx x<nn))) ho< |
431 | 83 |
84 -- another form of infinite | |
85 -- pair-ord< : {x : Ordinal } → Set n | |
86 pair-ord< : {x : HOD } → ( {y : HOD } → & y o< next (odmax y) ) → & ( x , x ) o< next (& x) | |
87 pair-ord< {x} ho< = subst (λ k → & (x , x) o< k ) lemmab0 lemmab1 where | |
88 lemmab0 : next (odmax (x , x)) ≡ next (& x) | |
89 lemmab0 = trans (cong (λ k → next k) (omxx _)) (sym nexto≡) | |
90 lemmab1 : & (x , x) o< next ( odmax (x , x)) | |
91 lemmab1 = ho< | |
92 | |
93 trans-⊆ : { A B C : HOD} → A ⊆ B → B ⊆ C → A ⊆ C | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
94 trans-⊆ A⊆B B⊆C ab = B⊆C (A⊆B ab) |
431 | 95 |
1126 | 96 trans-⊂ : { A B C : HOD} → A ⊂ B → B ⊂ C → A ⊂ C |
97 trans-⊂ ⟪ A<B , A⊆B ⟫ ⟪ B<C , B⊆C ⟫ = ⟪ ordtrans A<B B<C , (λ ab → B⊆C (A⊆B ab)) ⟫ | |
98 | |
431 | 99 refl-⊆ : {A : HOD} → A ⊆ A |
1096 | 100 refl-⊆ x = x |
431 | 101 |
102 od⊆→o≤ : {x y : HOD } → x ⊆ y → & x o< osuc (& y) | |
1096 | 103 od⊆→o≤ {x} {y} lt = ⊆→o≤ {x} {y} (λ {z} x>z → subst (λ k → def (od y) k ) &iso (lt (d→∋ x x>z))) |
431 | 104 |
480 | 105 ⊆→= : {F U : HOD} → F ⊆ U → U ⊆ F → F =h= U |
1096 | 106 ⊆→= {F} {U} FU UF = record { eq→ = λ {x} lt → subst (λ k → odef U k) &iso (FU (subst (λ k → odef F k) (sym &iso) lt) ) |
107 ; eq← = λ {x} lt → subst (λ k → odef F k) &iso (UF (subst (λ k → odef U k) (sym &iso) lt) ) } | |
480 | 108 |
519 | 109 ¬A∋x→A≡od∅ : (A : HOD) → {x : HOD} → A ∋ x → ¬ ( & A ≡ o∅ ) |
110 ¬A∋x→A≡od∅ A {x} ax a=0 = ¬x<0 ( subst (λ k → & x o< k) a=0 (c<→o< ax )) | |
111 | |
431 | 112 subset-lemma : {A x : HOD } → ( {y : HOD } → x ∋ y → (A ∩ x ) ∋ y ) ⇔ ( x ⊆ A ) |
113 subset-lemma {A} {x} = record { | |
1096 | 114 proj1 = λ lt x∋z → subst (λ k → odef A k ) &iso ( proj1 (lt (subst (λ k → odef x k) (sym &iso) x∋z ) )) |
115 ; proj2 = λ x⊆A lt → ⟪ x⊆A lt , lt ⟫ | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
116 } |
431 | 117 |
118 ω<next-o∅ : {y : Ordinal} → infinite-d y → y o< next o∅ | |
119 ω<next-o∅ {y} lt = <odmax infinite lt | |
120 | |
121 nat→ω : Nat → HOD | |
122 nat→ω Zero = od∅ | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
123 nat→ω (Suc y) = Union (nat→ω y , (nat→ω y , nat→ω y)) |
431 | 124 |
125 ω→nato : {y : Ordinal} → infinite-d y → Nat | |
126 ω→nato iφ = Zero | |
127 ω→nato (isuc lt) = Suc (ω→nato lt) | |
128 | |
129 ω→nat : (n : HOD) → infinite ∋ n → Nat | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
130 ω→nat n = ω→nato |
431 | 131 |
132 ω∋nat→ω : {n : Nat} → def (od infinite) (& (nat→ω n)) | |
133 ω∋nat→ω {Zero} = subst (λ k → def (od infinite) k) (sym ord-od∅) iφ | |
134 ω∋nat→ω {Suc n} = subst (λ k → def (od infinite) k) lemma (isuc ( ω∋nat→ω {n})) where | |
135 lemma : & (Union (* (& (nat→ω n)) , (* (& (nat→ω n)) , * (& (nat→ω n))))) ≡ & (nat→ω (Suc n)) | |
136 lemma = subst (λ k → & (Union (k , ( k , k ))) ≡ & (nat→ω (Suc n))) (sym *iso) refl | |
137 | |
138 pair1 : { x y : HOD } → (x , y ) ∋ x | |
139 pair1 = case1 refl | |
140 | |
141 pair2 : { x y : HOD } → (x , y ) ∋ y | |
142 pair2 = case2 refl | |
143 | |
144 single : {x y : HOD } → (x , x ) ∋ y → x ≡ y | |
145 single (case1 eq) = ==→o≡ ( ord→== (sym eq) ) | |
146 single (case2 eq) = ==→o≡ ( ord→== (sym eq) ) | |
147 | |
1096 | 148 single& : {x y : Ordinal } → odef (* x , * x ) y → x ≡ y |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
149 single& (case1 eq) = sym (trans eq &iso) |
1096 | 150 single& (case2 eq) = sym (trans eq &iso) |
151 | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
152 open import Relation.Binary.HeterogeneousEquality as HE using (_≅_ ) |
431 | 153 -- postulate f-extensionality : { n m : Level} → HE.Extensionality n m |
154 | |
1096 | 155 pair=∨ : {a b c : Ordinal } → odef (* a , * b) c → ( a ≡ c ) ∨ ( b ≡ c ) |
156 pair=∨ {a} {b} {c} (case1 c=a) = case1 ( sym (trans c=a &iso)) | |
157 pair=∨ {a} {b} {c} (case2 c=b) = case2 ( sym (trans c=b &iso)) | |
158 | |
431 | 159 ω-prev-eq1 : {x y : Ordinal} → & (Union (* y , (* y , * y))) ≡ & (Union (* x , (* x , * x))) → ¬ (x o< y) |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
160 ω-prev-eq1 {x} {y} eq x<y with eq→ (ord→== eq) record { owner = & (* y , * y) ; ao = case2 refl |
1096 | 161 ; ox = subst (λ k → odef k (& (* y))) (sym *iso) (case1 refl) } -- (* x , (* x , * x)) ∋ * y |
162 ... | record { owner = u ; ao = xxx∋u ; ox = uy } with xxx∋u | |
163 ... | case1 u=x = ⊥-elim ( o<> x<y (osucprev (begin | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
164 osuc y ≡⟨ sym (cong osuc &iso) ⟩ |
1096 | 165 osuc (& (* y)) ≤⟨ osucc (c<→o< {* y} {* u} uy) ⟩ -- * x ≡ * u ∋ * y |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
166 & (* u) ≡⟨ &iso ⟩ |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
167 u ≡⟨ u=x ⟩ |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
168 & (* x) ≡⟨ &iso ⟩ |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
169 x ∎ ))) where open o≤-Reasoning O |
1096 | 170 ... | case2 u=xx = ⊥-elim (o<¬≡ ( begin |
171 x ≡⟨ single& (subst₂ (λ j k → odef j k ) (begin | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
172 * u ≡⟨ cong (*) u=xx ⟩ |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
173 * (& (* x , * x)) ≡⟨ *iso ⟩ |
1096 | 174 (* x , * x ) ∎ ) &iso uy ) ⟩ -- (* x , * x ) ∋ * y |
175 y ∎ ) x<y) where open ≡-Reasoning | |
431 | 176 |
177 ω-prev-eq : {x y : Ordinal} → & (Union (* y , (* y , * y))) ≡ & (Union (* x , (* x , * x))) → x ≡ y | |
178 ω-prev-eq {x} {y} eq with trio< x y | |
179 ω-prev-eq {x} {y} eq | tri< a ¬b ¬c = ⊥-elim (ω-prev-eq1 eq a) | |
180 ω-prev-eq {x} {y} eq | tri≈ ¬a b ¬c = b | |
181 ω-prev-eq {x} {y} eq | tri> ¬a ¬b c = ⊥-elim (ω-prev-eq1 (sym eq) c) | |
182 | |
183 ω-∈s : (x : HOD) → Union ( x , (x , x)) ∋ x | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
184 ω-∈s x = record { owner = & ( x , x ) ; ao = case2 refl ; ox = subst₂ (λ j k → odef j k ) (sym *iso) refl (case2 refl) } |
431 | 185 |
186 ωs≠0 : (x : HOD) → ¬ ( Union ( x , (x , x)) ≡ od∅ ) | |
187 ωs≠0 y eq = ⊥-elim ( ¬x<0 (subst (λ k → & y o< k ) ord-od∅ (c<→o< (subst (λ k → odef k (& y )) eq (ω-∈s y) ))) ) | |
188 | |
189 nat→ω-iso : {i : HOD} → (lt : infinite ∋ i ) → nat→ω ( ω→nat i lt ) ≡ i | |
190 nat→ω-iso {i} = ε-induction {λ i → (lt : infinite ∋ i ) → nat→ω ( ω→nat i lt ) ≡ i } ind i where | |
191 ind : {x : HOD} → ({y : HOD} → x ∋ y → (lt : infinite ∋ y) → nat→ω (ω→nat y lt) ≡ y) → | |
192 (lt : infinite ∋ x) → nat→ω (ω→nat x lt) ≡ x | |
193 ind {x} prev lt = ind1 lt *iso where | |
194 ind1 : {ox : Ordinal } → (ltd : infinite-d ox ) → * ox ≡ x → nat→ω (ω→nato ltd) ≡ x | |
195 ind1 {o∅} iφ refl = sym o∅≡od∅ | |
196 ind1 (isuc {x₁} ltd) ox=x = begin | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
197 nat→ω (ω→nato (isuc ltd) ) |
431 | 198 ≡⟨⟩ |
199 Union (nat→ω (ω→nato ltd) , (nat→ω (ω→nato ltd) , nat→ω (ω→nato ltd))) | |
200 ≡⟨ cong (λ k → Union (k , (k , k ))) lemma ⟩ | |
201 Union (* x₁ , (* x₁ , * x₁)) | |
202 ≡⟨ trans ( sym *iso) ox=x ⟩ | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
203 x |
431 | 204 ∎ where |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
205 open ≡-Reasoning |
431 | 206 lemma0 : x ∋ * x₁ |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
207 lemma0 = subst (λ k → odef k (& (* x₁))) (trans (sym *iso) ox=x) |
1096 | 208 record { owner = & ( * x₁ , * x₁ ) ; ao = case2 refl ; ox = subst (λ k → odef k (& (* x₁))) (sym *iso) (case1 refl) } |
431 | 209 lemma1 : infinite ∋ * x₁ |
210 lemma1 = subst (λ k → odef infinite k) (sym &iso) ltd | |
211 lemma3 : {x y : Ordinal} → (ltd : infinite-d x ) (ltd1 : infinite-d y ) → y ≡ x → ltd ≅ ltd1 | |
212 lemma3 iφ iφ refl = HE.refl | |
213 lemma3 iφ (isuc {y} ltd1) eq = ⊥-elim ( ¬x<0 (subst₂ (λ j k → j o< k ) &iso eq (c<→o< (ω-∈s (* y)) ))) | |
214 lemma3 (isuc {y} ltd) iφ eq = ⊥-elim ( ¬x<0 (subst₂ (λ j k → j o< k ) &iso (sym eq) (c<→o< (ω-∈s (* y)) ))) | |
215 lemma3 (isuc {x} ltd) (isuc {y} ltd1) eq with lemma3 ltd ltd1 (ω-prev-eq (sym eq)) | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
216 ... | t = HE.cong₂ (λ j k → isuc {j} k ) (HE.≡-to-≅ (ω-prev-eq eq)) t |
431 | 217 lemma2 : {x y : Ordinal} → (ltd : infinite-d x ) (ltd1 : infinite-d y ) → y ≡ x → ω→nato ltd ≡ ω→nato ltd1 |
218 lemma2 {x} {y} ltd ltd1 eq = lemma6 eq (lemma3 {x} {y} ltd ltd1 eq) where | |
219 lemma6 : {x y : Ordinal} → {ltd : infinite-d x } {ltd1 : infinite-d y } → y ≡ x → ltd ≅ ltd1 → ω→nato ltd ≡ ω→nato ltd1 | |
220 lemma6 refl HE.refl = refl | |
221 lemma : nat→ω (ω→nato ltd) ≡ * x₁ | |
222 lemma = trans (cong (λ k → nat→ω k) (lemma2 {x₁} {_} ltd (subst (λ k → infinite-d k ) (sym &iso) ltd) &iso ) ) ( prev {* x₁} lemma0 lemma1 ) | |
223 | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
224 |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
225 ω→nat-iso0 : (x : Nat) → {ox : Ordinal } → (ltd : infinite-d ox) → * ox ≡ nat→ω x → ω→nato ltd ≡ x |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
226 ω→nat-iso0 Zero iφ eq = refl |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
227 ω→nat-iso0 (Suc x) iφ eq = ⊥-elim ( ωs≠0 _ (trans (sym eq) o∅≡od∅ )) |
1100 | 228 ω→nat-iso0 Zero (isuc ltd) eq = ⊥-elim ( ωs≠0 _ (subst (λ k → k ≡ od∅ ) *iso eq )) |
229 ω→nat-iso0 (Suc i) (isuc {x} ltd) eq = cong Suc ( ω→nat-iso0 i ltd (lemma1 eq) ) where | |
230 lemma1 : * (& (Union (* x , (* x , * x)))) ≡ Union (nat→ω i , (nat→ω i , nat→ω i)) → * x ≡ nat→ω i | |
231 lemma1 eq = subst (λ k → * x ≡ k ) *iso (cong (λ k → * k) | |
232 ( ω-prev-eq (subst (λ k → _ ≡ k ) &iso (cong (λ k → & k ) (sym | |
233 (subst (λ k → _ ≡ Union ( k , ( k , k ))) (sym *iso ) eq )))))) | |
234 | |
431 | 235 ω→nat-iso : {i : Nat} → ω→nat ( nat→ω i ) (ω∋nat→ω {i}) ≡ i |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
236 ω→nat-iso {i} = ω→nat-iso0 i (ω∋nat→ω {i}) *iso |
431 | 237 |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
238 Repl⊆ : {A B : HOD} (A⊆B : A ⊆ B) → { ψa : ( x : HOD) → A ∋ x → HOD } { ψb : ( x : HOD) → B ∋ x → HOD } |
1106 | 239 → ( {z : Ordinal } → (az : odef A z ) → (ψa (* z) (subst (odef A) (sym &iso) az) ≡ ψb (* z) (subst (odef B) (sym &iso) (A⊆B az)))) |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
240 → Replace' A ψa ⊆ Replace' B ψb |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
241 Repl⊆ {A} {B} A⊆B {ψa} {ψb} eq record { z = z ; az = az ; x=ψz = x=ψz } = record { z = z ; az = A⊆B az |
1106 | 242 ; x=ψz = trans x=ψz (cong (&) (eq az) ) } |
243 | |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
244 PPP : {P : HOD} → Power P ∋ P |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
245 PPP {P} z pz = subst (λ k → odef k z ) *iso pz |
1106 | 246 |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
247 UPower⊆Q : {P Q : HOD} → P ⊆ Q → Union (Power P) ⊆ Q |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
248 UPower⊆Q {P} {Q} P⊆Q {z} record { owner = y ; ao = ppy ; ox = yz } = P⊆Q (ppy _ yz) |
1106 | 249 |
1113
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
250 UPower∩ : {P : HOD} → ({ p q : HOD } → P ∋ p → P ∋ q → P ∋ (p ∩ q)) |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
251 → { p q : HOD } → Union (Power P) ∋ p → Union (Power P) ∋ q → Union (Power P) ∋ (p ∩ q) |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
252 UPower∩ {P} each {p} {q} record { owner = x ; ao = ppx ; ox = xz } record { owner = y ; ao = ppy ; ox = yz } |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
253 = record { owner = & P ; ao = PPP ; ox = lem03 } where |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
254 lem03 : odef (* (& P)) (& (p ∩ q)) |
384ba5a3c019
fix Topology definition
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1106
diff
changeset
|
255 lem03 = subst (λ k → odef k (& (p ∩ q))) (sym *iso) ( each (ppx _ xz) (ppy _ yz) ) |
1150 | 256 |
257 -- ∋-irr : {X x : HOD} → (a b : X ∋ x ) → a ≡ b | |
258 -- ∋-irr {X} {x} _ _ = refl | |
259 -- is requed in | |
1151
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
260 Replace∩ : {X P Q : HOD} → {ψ : (x : HOD) → X ∋ x → HOD} → (P⊆X : P ⊆ X) → (Q⊆X : Q ⊆ X ) |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
261 → ( {x : HOD} → (a b : X ∋ x ) → ψ x a ≡ ψ x b ) |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
262 → (Replace' (P ∩ Q) (λ _ pq → ψ _ (P⊆X (proj1 pq )))) ⊆ ( Replace' P (λ _ p → ψ _ (P⊆X p)) ∩ Replace' Q (λ _ q → ψ _ (Q⊆X q))) |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
263 Replace∩ {X} {P} {Q} {ψ} P⊆X Q⊆X ψ-irr = lem04 where |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
264 lem04 : {x : Ordinal} → OD.def (od (Replace' (P ∩ Q) (λ z pq → ψ z (P⊆X (proj1 pq)) ))) x |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
265 → OD.def (od (Replace' P (λ z p → ψ z (P⊆X p)) ∩ Replace' Q (λ z q → ψ z (Q⊆X q)))) x |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
266 lem04 {x} record { z = z ; az = az ; x=ψz = x=ψz } = ⟪ |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
267 record { z = _ ; az = proj1 az ; x=ψz = trans x=ψz (cong (&)(ψ-irr _ _)) } , |
8a071bf52407
Finite intersection property to Compact done
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents:
1150
diff
changeset
|
268 record { z = _ ; az = proj2 az ; x=ψz = trans x=ψz (cong (&)(ψ-irr _ _)) } ⟫ |
1150 | 269 |