# HG changeset patch # User Shinji KONO # Date 1596623827 -32400 # Node ID f7d66c84bc26bd047f482d73dd526a1c3170c1bf # Parent cc7909f86841eab6a6fbecbd727c345b4411f90a ... diff -r cc7909f86841 -r f7d66c84bc26 OD.agda --- a/OD.agda Sat Aug 01 23:37:10 2020 +0900 +++ b/OD.agda Wed Aug 05 19:37:07 2020 +0900 @@ -143,8 +143,8 @@ _∋_ : ( a x : HOD ) → Set n _∋_ a x = odef a ( & x ) -_c<_ : ( x a : HOD ) → Set n -x c< a = a ∋ x +-- _c<_ : ( x a : HOD ) → Set n +-- x c< a = a ∋ x d→∋ : ( a : HOD ) { x : Ordinal} → odef a x → a ∋ (* x) d→∋ a lt = subst (λ k → odef a k ) (sym &iso) lt @@ -156,8 +156,8 @@ otrans x ))) -Func∋f = {!!} +-- Func∋f : {A B x : HOD} → ( f : HOD → HOD ) → ( (x : HOD ) → A ∋ x → B ∋ f x ) +-- → def Func (& (Replace A (λ x → < x , f x > ))) +-- Func∋f = {!!} -FuncP∋f : {A B x : HOD} → ( f : HOD → HOD ) → ( (x : HOD ) → A ∋ x → B ∋ f x ) - → odef (FuncP A B) (& (Replace A (λ x → < x , f x > ))) -FuncP∋f = {!!} +-- FuncP∋f : {A B x : HOD} → ( f : HOD → HOD ) → ( (x : HOD ) → A ∋ x → B ∋ f x ) +-- → odef (FuncP A B) (& (Replace A (λ x → < x , f x > ))) +-- FuncP∋f = {!!} -- Func→f : {A B f x : HOD} → def Func (& f) → (x : HOD ) → A ∋ x → ( HOD ∧ ((y : HOD ) → B ∋ y )) -- Func→f = {!!} @@ -68,14 +68,41 @@ -- onto : {A B f : HOD} → def Func (& f) → {!!} -- onto = {!!} +record Injection (A B : Ordinal ) : Set n where + field + i→ : (x : Ordinal ) → odef (* B) x → Ordinal + iA : (x : Ordinal ) → ( lt : odef (* B) x ) → odef (* A) ( i→ x lt ) + iiso : (x y : Ordinal ) → ( ltx : odef (* B) x ) ( lty : odef (* B) y ) → i→ x ltx ≡ i→ y lty → x ≡ y + record Bijection (A B : Ordinal ) : Set n where field - fun→ : Ordinal → Ordinal - fun← : Ordinal → Ordinal - fun→inA : (x : Ordinal) → odef (* A) ( fun→ x ) - fun←inB : (x : Ordinal) → odef (* B) ( fun← x ) - fiso→ : (x : Ordinal ) → odef (* B) x → fun→ ( fun← x ) ≡ x - fiso← : (x : Ordinal ) → odef (* A) x → fun← ( fun→ x ) ≡ x + fun← : (x : Ordinal ) → odef (* A) x → Ordinal + fun→ : (x : Ordinal ) → odef (* B) x → Ordinal + funB : (x : Ordinal ) → ( lt : odef (* A) x ) → odef (* B) ( fun← x lt ) + funA : (x : Ordinal ) → ( lt : odef (* B) x ) → odef (* A) ( fun→ x lt ) + fiso← : (x : Ordinal ) → ( lt : odef (* B) x ) → fun← ( fun→ x lt ) ( funA x lt ) ≡ x + fiso→ : (x : Ordinal ) → ( lt : odef (* A) x ) → fun→ ( fun← x lt ) ( funB x lt ) ≡ x +Bernstein : {a b : Ordinal } → Injection a b → Injection b a → Bijection a b +Bernstein = {!!} + +_=c=_ : ( A B : HOD ) → Set n +A =c= B = Bijection ( & A ) ( & B ) + +_c<_ : ( A B : HOD ) → Set n +A c< B = Injection (& A) (& B) + Card : OD Card = record { def = λ x → (a : Ordinal) → a o< x → ¬ Bijection a x } + +record Cardinal (a : Ordinal ) : Set (suc n) where + field + card : Ordinal + ciso : Bijection a card + cmax : (x : Ordinal) → card o< x → ¬ Bijection a x + +Cantor1 : { u : HOD } → u c< Power u +Cantor1 = {!!} + +Cantor2 : { u : HOD } → ¬ ( u =c= Power u ) +Cantor2 = {!!} diff -r cc7909f86841 -r f7d66c84bc26 zf-in-agda.html --- a/zf-in-agda.html Sat Aug 01 23:37:10 2020 +0900 +++ b/zf-in-agda.html Wed Aug 05 19:37:07 2020 +0900 @@ -823,9 +823,9 @@

-   ¬OD-order : ( od→ord : OD  → Ordinal ) 
-      → ( ord→od : Ordinal  → OD ) → ( { x y : OD  }  → def y ( od→ord x ) → od→ord x o< od→ord y) → ⊥
-   ¬OD-order od→ord ord→od c<→o< = ?
+   ¬OD-order : ( & : OD  → Ordinal ) 
+      → ( * : Ordinal  → OD ) → ( { x y : OD  }  → def y ( & x ) → & x o< & y) → ⊥
+   ¬OD-order & * c<→o< = ?
 
 
Actualy we can prove this contrdction, so we need some restrctions on OD. @@ -862,10 +862,10 @@

-  od→ord : HOD  → Ordinal 
-  ord→od : Ordinal  → HOD  
-  oiso   :  {x : HOD }      → ord→od ( od→ord x ) ≡ x
-  diso   :  {x : Ordinal } → od→ord ( ord→od x ) ≡ x
+  & : HOD  → Ordinal 
+  * : Ordinal  → HOD  
+  oiso   :  {x : HOD }      → * ( & x ) ≡ x
+  diso   :  {x : Ordinal } → & ( * x ) ≡ x
 
 
we can check an HOD is an element of the OD using def. @@ -875,14 +875,14 @@
     _∋_ : ( A x : HOD  ) → Set n
-    _∋_  A x  = def (od A) ( od→ord x )
+    _∋_  A x  = def (od A) ( & x )
 
 
In ψ : Ordinal → Set, if A is a record { def = λ x → ψ x } , then

-    A x = def A ( od→ord x ) = ψ (od→ord x)
+    A x = def A ( & x ) = ψ (& x)
 
 
They say the existing of the mappings can be proved in Classical Set Theory, but we @@ -898,7 +898,7 @@

-     def (od y) ( od→ord x )
+     def (od y) ( & x )
 
 
An elements of HOD should be defined before the HOD, that is, an ordinal corresponding an elements @@ -907,15 +907,15 @@

-  c<→o<  :  {x y : HOD  }   → def (od y) ( od→ord x ) → od→ord x o< od→ord y
-  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → od→ord y o< osuc (od→ord z)
+  c<→o<  :  {x y : HOD  }   → def (od y) ( & x ) → & x o< & y
+  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → & y o< osuc (& z)
 
 
If wa assumes reverse order preservation,

-  o<→c<  : {n : Level} {x y : Ordinal  } → x o< y → def (ord→od y) x 
+  o<→c<  : {n : Level} {x y : Ordinal  } → x o< y → def (* y) x 
 
 
∀ x ∋ ∅ becomes true, which manes all OD becomes Ordinals in the model. @@ -986,7 +986,7 @@ data infinite-d : ( x : Ordinal ) → Set n where iφ : infinite-d o∅ isuc : {x : Ordinal } → infinite-d x → - infinite-d (od→ord ( Union (ord→od x , (ord→od x , ord→od x ) ) )) + infinite-d (& ( Union (* x , (* x , * x ) ) )) Union (x , ( x , x )) should be an direct successor of x, but we cannot prove it in our model. @@ -1026,7 +1026,7 @@
     _,_ : HOD  → HOD  → HOD 
-    x , y = record { od = record { def = λ t → (t ≡ od→ord x ) ∨ ( t ≡ od→ord y ) } ; odmax = ? ; <odmax = ? }
+    x , y = record { od = record { def = λ t → (t ≡ & x ) ∨ ( t ≡ & y ) } ; odmax = ? ; <odmax = ? }
 
 
It is easy to find out odmax from odmax of x and y. @@ -1044,7 +1044,7 @@ pair→ x y t p = ? -In this program, type of p is ( x , y ) ∋ t , that is def ( x , y ) that is, (t ≡ od→ord x ) ∨ ( t ≡ od→ord y ) . +In this program, type of p is ( x , y ) ∋ t , that is def ( x , y ) that is, (t ≡ & x ) ∨ ( t ≡ & y ) .

Since _∨_ is a data, it can be developed as (C-c C-c : agda2-make-case ).

@@ -1067,7 +1067,7 @@

-    t≡x : od→ord t ≡ od→ord x
+    t≡x : & t ≡ & x
 
 
which is shown by an Agda command (C-C C-E : agda2-show-context ). @@ -1124,8 +1124,8 @@

-   eq→ (extensionality0 {A} {B} eq ) {x} d = odef-iso  {A} {B} (sym diso) (proj1 (eq (ord→od x))) d
-   eq← (extensionality0 {A} {B} eq ) {x} d = odef-iso  {B} {A} (sym diso) (proj2 (eq (ord→od x))) d
+   eq→ (extensionality0 {A} {B} eq ) {x} d = odef-iso  {A} {B} (sym diso) (proj1 (eq (* x))) d
+   eq← (extensionality0 {A} {B} eq ) {x} d = odef-iso  {B} {A} (sym diso) (proj2 (eq (* x))) d
 
 
where @@ -1138,9 +1138,20 @@
-

Validity of Axiom of Extensionality

+

The uniqueness of HOD

+To prove extensionality or other we need ==→o≡. +

+Since we have ==→o≡ , so odmax have to be unique. We should have odmaxmin in HOD. +We can calculate the minimum using sup if we have bound but it is tedius. +Only Select has non minimum odmax. We have the same problem on 'def' itself, but we leave it, that is we assume the +assumption of predicates of Agda have a unique form, it is something like the +functional extensionality assumption. +

+ +


+

Validity of Axiom of Extensionality

If we can derive (w ∋ A) ⇔ (w ∋ B) from od A == od B, the axiom becomes valid, but it seems impossible, so we assumes

@@ -1159,7 +1170,7 @@


-

Axiom of infinity

+

Axiom of infinity

It means it has ω as a ZF Set. It is ususally written like this. @@ -1180,17 +1191,17 @@


-

ω in HOD

+

ω in HOD

-To define an OD which arrows od→ord (Union (x , (x , x))) as a predicate, we can use Agda data structure. +To define an OD which arrows & (Union (x , (x , x))) as a predicate, we can use Agda data structure.

     data infinite-d  : ( x : Ordinal  ) → Set n where
         iφ :  infinite-d o∅
         isuc : {x : Ordinal  } →   infinite-d  x  →
-                infinite-d  (od→ord ( Union (ord→od x , (ord→od x , ord→od x ) ) ))
+                infinite-d  (& ( Union (* x , (* x , * x ) ) ))
 
 
It has simular structure as Data.Nat in Agda, and it defines a correspendence of HOD and the data structure. Now @@ -1202,20 +1213,48 @@ infinite = record { od = record { def = λ x → infinite-d x } ; odmax = ? ; <odmax = ? } -So what is the bound of ω? Analyzing the definition, it depends on the value of od→ord (x , x), which -cannot know the aboslute value. This is because we don't have constructive definition of od→ord : HOD → Ordinal. +So what is the bound of ω? Analyzing the definition, it depends on the value of & (x , x), which +cannot know the aboslute value. This is because we don't have constructive definition of & : HOD → Ordinal.


-

HOD Ordrinal mapping

+

HOD and Agda data structure

+We may have +

+ +

+    a HOD <=> Agda Data Strucure
+
+
+as a data in Agda. Ex. +

+ +

+    data ord-pair : (p : Ordinal) → Set n where
+       pair : (x y : Ordinal ) → ord-pair ( & ( < * x , * y > ) )
+    ZFProduct : OD
+    ZFProduct = record { def = λ x → ord-pair x }
+    pi1 : { p : Ordinal } →   ord-pair p →  Ordinal
+    pi1 ( pair x y) = x
+    π1 : { p : HOD } → def ZFProduct (& p) → HOD
+    π1 lt = * (pi1 lt )
+    p-iso :  { x  : HOD } → (p : def ZFProduct (&  x) ) → < π1 p , π2 p > ≡ x
+    p-iso {x} p = ord≡→≡ (op-iso p) 
+
+
+ +
+

HOD Ordrinal mapping

+ +

We have large freedom on HOD. We reqest no minimality on odmax, so it may arbitrary larger. The address of HOD can be larger at least it have to be larger than the content's address. We only have a relative ordering such as

-    pair-xx<xy : {x y : HOD} → od→ord (x , x) o< osuc (od→ord (x , y) )
-    pair<y : {x y : HOD } → y ∋ x  → od→ord (x , x) o< osuc (od→ord y)
+    pair-xx<xy : {x y : HOD} → & (x , x) o< osuc (& (x , y) )
+    pair<y : {x y : HOD } → y ∋ x  → & (x , x) o< osuc (& y)
 
 
Basicaly, we cannot know the concrete address of HOD other than empty set. @@ -1225,7 +1264,7 @@


-

Possible restriction on HOD

+

Possible restriction on HOD

We need some restriction on the HOD-Ordinal mapping. Simple one is this.

@@ -1239,7 +1278,7 @@

         hod-ord< :  {x : HOD } → Set n
-        hod-ord< {x} =  od→ord x o< next (odmax x)
+        hod-ord< {x} =  & x o< next (odmax x)
 
 
next : Ordinal → Ordinal means imediate next limit ordinal of x. It supress unecessary space between address of HOD and @@ -1250,45 +1289,45 @@


-

increment pase of address of HOD

+

increment pase of address of HOD

Assuming, hod-ord< , we have

-    pair-ord< : {x : HOD } → ( {y : HOD } → od→ord y o< next (odmax y) ) → od→ord ( x , x ) o< next (od→ord x)
-    pair-ord< {x} ho< = subst (λ k → od→ord (x , x) o< k ) lemmab0 lemmab1  where
-           lemmab0 : next (odmax (x , x)) ≡ next (od→ord x)
+    pair-ord< : {x : HOD } → ( {y : HOD } → & y o< next (odmax y) ) → & ( x , x ) o< next (& x)
+    pair-ord< {x} ho< = subst (λ k → & (x , x) o< k ) lemmab0 lemmab1  where
+           lemmab0 : next (odmax (x , x)) ≡ next (& x)
 
 
So the address of ( x , x) and Union (x , (x , x)) is restricted in the limit ordinal. This makes ω bound. We can prove

-    infinite-bound : ({x : HOD} → od→ord x o< next (odmax x)) → {y : Ordinal} → infinite-d y → y o< next o∅
+    infinite-bound : ({x : HOD} → & x o< next (odmax x)) → {y : Ordinal} → infinite-d y → y o< next o∅
 
 
-We also notice that if we have od→ord (x , x) ≡ osuc (od→ord x), c<→o< can be drived from ⊆→o≤ . +We also notice that if we have & (x , x) ≡ osuc (& x), c<→o< can be drived from ⊆→o≤ .

-    ⊆→o≤→c<→o< : ({x : HOD} → od→ord (x , x) ≡ osuc (od→ord x) )
-       →  ({y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → od→ord y o< osuc (od→ord z) )
-       →   {x y : HOD  }   → def (od y) ( od→ord x ) → od→ord x o< od→ord y 
+    ⊆→o≤→c<→o< : ({x : HOD} → & (x , x) ≡ osuc (& x) )
+       →  ({y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → & y o< osuc (& z) )
+       →   {x y : HOD  }   → def (od y) ( & x ) → & x o< & y 
 
 

-

Non constructive assumptions so far

+

Non constructive assumptions so far

-  od→ord : HOD  → Ordinal 
-  ord→od : Ordinal  → HOD  
-  c<→o<  :  {x y : HOD  }   → def (od y) ( od→ord x ) → od→ord x o< od→ord y
-  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → od→ord y o< osuc (od→ord z)
-  oiso   :  {x : HOD }      → ord→od ( od→ord x ) ≡ x
-  diso   :  {x : Ordinal }  → od→ord ( ord→od x ) ≡ x
+  & : HOD  → Ordinal 
+  * : Ordinal  → HOD  
+  c<→o<  :  {x y : HOD  }   → def (od y) ( & x ) → & x o< & y
+  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → & y o< osuc (& z)
+  oiso   :  {x : HOD }      → * ( & x ) ≡ x
+  diso   :  {x : Ordinal }  → & ( * x ) ≡ x
   ==→o≡  :  {x y : HOD  }   → (od x == od y) → x ≡ y
   sup-o  :  (A : HOD) → (     ( x : Ordinal ) → def (od A) x →  Ordinal ) →  Ordinal 
   sup-o< :  (A : HOD) → { ψ : ( x : Ordinal ) → def (od A) x →  Ordinal } → ∀ {x : Ordinal } → (lt : def (od A) x ) → ψ x lt o<  sup-o A ψ 
@@ -1296,7 +1335,7 @@
 

-

Axiom which have negation form

+

Axiom which have negation form

@@ -1320,7 +1359,7 @@


-

Union

+

Union

The original form of the Axiom of Union is

@@ -1341,8 +1380,8 @@

     Union : HOD  → HOD   
-    Union U = record { od = record { def = λ x → ¬ (∀ (u : Ordinal ) → ¬ ((odef U u) ∧ (odef (ord→od u) x)))  }
-       ; odmax = osuc (od→ord U) ; <odmax = ?  } 
+    Union U = record { od = record { def = λ x → ¬ (∀ (u : Ordinal ) → ¬ ((odef U u) ∧ (odef (* u) x)))  }
+       ; odmax = osuc (& U) ; <odmax = ?  } 
 
 
The bound of Union is evident, but its proof is rather complicated. @@ -1352,12 +1391,12 @@
          union→ :  (X z u : HOD) → (X ∋ u) ∧ (u ∋ z) → Union X ∋ z
-         union→ X z u xx not = ⊥-elim ( not (od→ord u) ( record { proj1 = proj1 xx
-              ; proj2 = subst ( λ k → odef k (od→ord z)) (sym oiso) (proj2 xx) } ))
+         union→ X z u xx not = ⊥-elim ( not (& u) ( record { proj1 = proj1 xx
+              ; proj2 = subst ( λ k → odef k (& z)) (sym oiso) (proj2 xx) } ))
          union← :  (X z : HOD) (X∋z : Union X ∋ z) →  ¬  ( (u : HOD ) → ¬ ((X ∋  u) ∧ (u ∋ z )))
          union← X z UX∋z =  FExists _ lemma UX∋z where
-              lemma : {y : Ordinal} → odef X y ∧ odef (ord→od y) (od→ord z) → ¬ ((u : HOD) → ¬ (X ∋ u) ∧ (u ∋ z))
-              lemma {y} xx not = not (ord→od y) record { proj1 = subst ( λ k → odef X k ) (sym diso) (proj1 xx ) ; proj2 = proj2 xx } 
+              lemma : {y : Ordinal} → odef X y ∧ odef (* y) (& z) → ¬ ((u : HOD) → ¬ (X ∋ u) ∧ (u ∋ z))
+              lemma {y} xx not = not (* y) record { proj1 = subst ( λ k → odef X k ) (sym diso) (proj1 xx ) ; proj2 = proj2 xx } 
 
 
where @@ -1375,7 +1414,7 @@


-

Axiom of replacement

+

Axiom of replacement

We can replace the elements of a set by a function and it becomes a set. From the book,

@@ -1404,7 +1443,7 @@

     in-codomain : (X : OD  ) → ( ψ : OD  → OD  ) → OD 
-    in-codomain  X ψ = record { def = λ x → ¬ ( (y : Ordinal ) → ¬ ( def X y ∧  ( x ≡ od→ord (ψ (ord→od y )))))  }
+    in-codomain  X ψ = record { def = λ x → ¬ ( (y : Ordinal ) → ¬ ( def X y ∧  ( x ≡ & (ψ (* y )))))  }
 
 
in-codomain is a logical relation-ship, and it is written in OD. @@ -1412,10 +1451,10 @@
     Replace : HOD  → (HOD  → HOD) → HOD 
-    Replace X ψ = record { od = record { def = λ x → (x o< sup-o X (λ y X∋y → od→ord (ψ (ord→od y)))) ∧ def (in-codomain X ψ) x }
+    Replace X ψ = record { od = record { def = λ x → (x o< sup-o X (λ y X∋y → & (ψ (* y)))) ∧ def (in-codomain X ψ) x }
        ; odmax = rmax ; <odmax = rmax<} where 
           rmax : Ordinal
-          rmax = sup-o X (λ y X∋y → od→ord (ψ (ord→od y)))
+          rmax = sup-o X (λ y X∋y → & (ψ (* y)))
           rmax< :  {y : Ordinal} → (y o< rmax) ∧ def (in-codomain X ψ) y → y o< rmax
           rmax< lt = proj1 lt
 
@@ -1426,7 +1465,7 @@
 


-

Validity of Power Set Axiom

+

Validity of Power Set Axiom

The original Power Set Axiom is this.

@@ -1484,7 +1523,7 @@ Ord : ( a : Ordinal ) → OD Ord a = record { def = λ y → y o< a } Def : (A : OD ) → OD - Def A = Ord ( sup-o ( λ x → od→ord ( ZFSubset A (ord→od x )) ) ) + Def A = Ord ( sup-o ( λ x → & ( ZFSubset A (* x )) ) )

This is slight larger than Power A, so we replace all elements x by A ∩ x (some of them may empty). @@ -1492,7 +1531,7 @@
     Power : OD  → OD 
-    Power A = Replace (Def (Ord (od→ord A))) ( λ x → A ∩ x )
+    Power A = Replace (Def (Ord (& A))) ( λ x → A ∩ x )
 
 
Creating Power Set of Ordinals is rather easy, then we use replacement axiom on A ∩ x since we have this. @@ -1519,7 +1558,7 @@
-

Axiom of regularity, Axiom of choice, ε-induction

+

Axiom of regularity, Axiom of choice, ε-induction

Axiom of regularity requires non self intersectable elements (which is called minimum), if we @@ -1531,8 +1570,8 @@

   minimal : (x : HOD  ) → ¬ (x == od∅ )→ OD
-  x∋minimal : (x : HOD  ) → ( ne : ¬ (x == od∅ ) ) → def x ( od→ord ( minimal x ne ) )
-  minimal-1 : (x : HOD  ) → ( ne : ¬ (x == od∅ ) ) → (y : HOD ) → ¬ ( def (minimal x ne) (od→ord y)) ∧ (def x (od→ord  y) )
+  x∋minimal : (x : HOD  ) → ( ne : ¬ (x == od∅ ) ) → def x ( & ( minimal x ne ) )
+  minimal-1 : (x : HOD  ) → ( ne : ¬ (x == od∅ ) ) → (y : HOD ) → ¬ ( def (minimal x ne) (& y)) ∧ (def x (&  y) )
 
 
We can avoid this using ε-induction (a predicate is valid on all set if the predicate is true on some element of set). @@ -1566,7 +1605,7 @@


-

Axiom of choice and Law of Excluded Middle

+

Axiom of choice and Law of Excluded Middle

In our model, since HOD has a mapping to Ordinals, it has evident order, which means well ordering theorem is valid, but it don't have correct form of the axiom yet. They say well ordering axiom is equivalent to the axiom of choice, but it requires law of the exclude middle. @@ -1586,23 +1625,23 @@


-

Relation-ship among ZF axiom

+

Relation-ship among ZF axiom


-

Non constructive assumption in our model

+

Non constructive assumption in our model

mapping between HOD and Ordinals

-  od→ord : HOD  → Ordinal
-  ord→od : Ordinal  → OD
-  oiso   :  {x : HOD }      → ord→od ( od→ord x ) ≡ x
-  diso   :  {x : Ordinal } → od→ord ( ord→od x ) ≡ x
-  c<→o<  :  {x y : HOD  }   → def y ( od→ord x ) → od→ord x o< od→ord y
-  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → od→ord y o< osuc (od→ord z)
+  & : HOD  → Ordinal
+  * : Ordinal  → OD
+  oiso   :  {x : HOD }      → * ( & x ) ≡ x
+  diso   :  {x : Ordinal } → & ( * x ) ≡ x
+  c<→o<  :  {x y : HOD  }   → def y ( & x ) → & x o< & y
+  ⊆→o≤   :  {y z : HOD  }   → ({x : Ordinal} → def (od y) x → def (od z) x ) → & y o< osuc (& z)
 
 
Equivalence on OD @@ -1624,7 +1663,7 @@

-  hod-ord< : {x : HOD} →  od→ord x o< next (odmax x)
+  hod-ord< : {x : HOD} →  & x o< next (odmax x)
 
 
Axiom of choice and strong axiom of regularity. @@ -1632,15 +1671,102 @@
   minimal : (x : HOD  ) → ¬ (x =h= od∅ )→ HOD 
-  x∋minimal : (x : HOD  ) → ( ne : ¬ (x =h= od∅ ) ) → odef x ( od→ord ( minimal x ne ) )
-  minimal-1 : (x : HOD  ) → ( ne : ¬ (x =h= od∅ ) ) → (y : HOD ) → ¬ ( odef (minimal x ne) (od→ord y)) ∧ (odef x (od→ord  y) )
+  x∋minimal : (x : HOD  ) → ( ne : ¬ (x =h= od∅ ) ) → odef x ( & ( minimal x ne ) )
+  minimal-1 : (x : HOD  ) → ( ne : ¬ (x =h= od∅ ) ) → (y : HOD ) → ¬ ( odef (minimal x ne) (& y)) ∧ (odef x (&  y) )
 
 

-

So it this correct?

+

V

+The cumulative hierarchy +

+    V 0 := ∅ 
+    V α + 1 := P ( V α ) 
+    V α := ⋃ { V β | β < α }
+
+
+Using TransFinite induction +

+ +

+    V : ( β : Ordinal ) → HOD
+    V β = TransFinite  V1 β where
+       V1 : (x : Ordinal ) → ( ( y : Ordinal) → y o< x → HOD )  → HOD
+       V1 x V0 with trio< x o∅
+       V1 x V0 | tri< a ¬b ¬c = ⊥-elim ( ¬x<0 a)
+       V1 x V0 | tri≈ ¬a refl ¬c = Ord o∅
+       V1 x V0 | tri> ¬a ¬b c with Oprev-p  x
+       V1 x V0 | tri> ¬a ¬b c | yes p = Power ( V0 (Oprev.oprev p ) (subst (λ k → _ o< k) (Oprev.oprev=x  p) <-osuc ))
+       V1 x V0 | tri> ¬a ¬b c | no ¬p = 
+            record { od = record { def = λ y → (y o< x ) ∧ ((lt : y o< x ) →  odef (V0 y lt) x ) } ; 
+             odmax = x; <odmax = λ {x} lt → proj1 lt }
+
+
+In our system, clearly V ⊆ HOD。 +

+ +


+

L

+The constructible Sets +
+    L 0 := ∅ 
+    L α + 1 := Df (L α)   -- Definable Power Set
+    V α := ⋃ { L β | β < α }
+
+
+What is Df? In our system, Power x is definable by Sup. +

+ +

+    record Definitions  : Set (suc n) where
+       field
+          Definition : HOD → HOD   
+    open Definitions
+    Df : Definitions → (x : HOD) → HOD
+    Df D x = Power x ∩ Definition D x 
+
+
+ +
+

L

+ +

+ +

+    L : ( β : Ordinal ) → Definitions → HOD
+    L β D = TransFinite  L1 β where
+       L1 : (x : Ordinal ) → ( ( y : Ordinal) → y o< x → HOD )  → HOD
+       L1 x L0 with trio< x o∅
+       L1 x L0 | tri< a ¬b ¬c = ⊥-elim ( ¬x<0 a)
+       L1 x L0 | tri≈ ¬a refl ¬c = Ord o∅
+       L1 x L0 | tri> ¬a ¬b c with Oprev-p  x
+       L1 x L0 | tri> ¬a ¬b c | yes p = Df D ( L0 (Oprev.oprev p ) (subst (λ k → _ o< k) (Oprev.oprev=x  p) <-osuc ))
+       L1 x L0 | tri> ¬a ¬b c | no ¬p = 
+            record { od = record { def = λ y → (y o< x ) ∧ ((lt : y o< x ) →  odef (L0 y lt) x ) } ; 
+                odmax = x; <odmax = λ {x} lt → proj1 lt }
+
+
+ +
+

V=L

+ +

+ +

+    V=L0 : Set (suc n)
+    V=L0 = (x : Ordinal) → V x ≡  L x record { Definition = λ y → y }
+
+
+is obvious. Definitions should have some restrictions, such as it includes Nat. +

+ +


+

Some other ...

+ +
+

So it this correct?

Our axiom are syntactically the same in the text book, but negations are slightly different.

If we assumes excluded middle, these are exactly same. @@ -1658,7 +1784,7 @@


-

How to use Agda Set Theory

+

How to use Agda Set Theory

Assuming record ZF, classical set theory can be developed. If necessary, axiom of choice can be postulated or assuming law of excluded middle.

@@ -1669,7 +1795,7 @@


-

Topos and Set Theory

+

Topos and Set Theory

Topos is a mathematical structure in Category Theory, which is a Cartesian closed category which has a sub-object classifier.

@@ -1687,7 +1813,7 @@


-

Cardinal number and Continuum hypothesis

+

Cardinal number and Continuum hypothesis

Axiom of choice is required to define cardinal number

definition of cardinal number is not yet done @@ -1705,7 +1831,7 @@


-

Filter

+

Filter

filter is a dual of ideal on boolean algebra or lattice. Existence on natural number @@ -1728,7 +1854,7 @@


-

Programming Mathematics

+

Programming Mathematics

Mathematics is a functional programming in Agda where proof is a value of a variable. The mathematical structure are

@@ -1753,7 +1879,7 @@


-

link

+

link

Summer school of foundation of mathematics (in Japanese)
https://www.sci.shizuoka.ac.jp/~math/yorioka/ss2019/

Foundation of axiomatic set theory (in Japanese)
https://www.sci.shizuoka.ac.jp/~math/yorioka/ss2019/sakai0.pdf @@ -1818,29 +1944,36 @@

  • pair in OD
  • Validity of Axiom of Pair
  • Equality of OD and Axiom of Extensionality -
  • Validity of Axiom of Extensionality -
  • Axiom of infinity -
  • ω in HOD -
  • HOD Ordrinal mapping -
  • Possible restriction on HOD -
  • increment pase of address of HOD -
  • Non constructive assumptions so far -
  • Axiom which have negation form -
  • Union -
  • Axiom of replacement -
  • Validity of Power Set Axiom -
  • Axiom of regularity, Axiom of choice, ε-induction -
  • Axiom of choice and Law of Excluded Middle -
  • Relation-ship among ZF axiom -
  • Non constructive assumption in our model -
  • So it this correct? -
  • How to use Agda Set Theory -
  • Topos and Set Theory -
  • Cardinal number and Continuum hypothesis -
  • Filter -
  • Programming Mathematics -
  • link +
  • The uniqueness of HOD +
  • Validity of Axiom of Extensionality +
  • Axiom of infinity +
  • ω in HOD +
  • HOD and Agda data structure +
  • HOD Ordrinal mapping +
  • Possible restriction on HOD +
  • increment pase of address of HOD +
  • Non constructive assumptions so far +
  • Axiom which have negation form +
  • Union +
  • Axiom of replacement +
  • Validity of Power Set Axiom +
  • Axiom of regularity, Axiom of choice, ε-induction +
  • Axiom of choice and Law of Excluded Middle +
  • Relation-ship among ZF axiom +
  • Non constructive assumption in our model +
  • V +
  • L +
  • L +
  • V=L +
  • Some other ... +
  • So it this correct? +
  • How to use Agda Set Theory +
  • Topos and Set Theory +
  • Cardinal number and Continuum hypothesis +
  • Filter +
  • Programming Mathematics +
  • link -
    Shinji KONO / Fri Jul 17 13:42:02 2020 +
    Shinji KONO / Tue Aug 4 18:09:41 2020 diff -r cc7909f86841 -r f7d66c84bc26 zf-in-agda.ind --- a/zf-in-agda.ind Sat Aug 01 23:37:10 2020 +0900 +++ b/zf-in-agda.ind Wed Aug 05 19:37:07 2020 +0900 @@ -588,9 +588,9 @@ Unfortunately this scheme does not work well. As we saw OD includes all Ordinals, which is a maximum of OD, but Ordinals has no maximum at all. So we have a contradction like - ¬OD-order : ( od→ord : OD → Ordinal ) - → ( ord→od : Ordinal → OD ) → ( { x y : OD } → def y ( od→ord x ) → od→ord x o< od→ord y) → ⊥ - ¬OD-order od→ord ord→od c<→o< = ? + ¬OD-order : ( & : OD → Ordinal ) + → ( * : Ordinal → OD ) → ( { x y : OD } → def y ( & x ) → & x o< & y) → ⊥ + ¬OD-order & * c<→o< = ? Actualy we can prove this contrdction, so we need some restrctions on OD. @@ -617,21 +617,21 @@ HOD is a predicate on Ordinals and the solution is bounded by some ordinal. If we have a mapping - od→ord : HOD → Ordinal - ord→od : Ordinal → HOD - oiso : {x : HOD } → ord→od ( od→ord x ) ≡ x - diso : {x : Ordinal } → od→ord ( ord→od x ) ≡ x + & : HOD → Ordinal + * : Ordinal → HOD + oiso : {x : HOD } → * ( & x ) ≡ x + diso : {x : Ordinal } → & ( * x ) ≡ x we can check an HOD is an element of the OD using def. A ∋ x can be define as follows. _∋_ : ( A x : HOD ) → Set n - _∋_ A x = def (od A) ( od→ord x ) + _∋_ A x = def (od A) ( & x ) In ψ : Ordinal → Set, if A is a record { def = λ x → ψ x } , then - A x = def A ( od→ord x ) = ψ (od→ord x) + A x = def A ( & x ) = ψ (& x) They say the existing of the mappings can be proved in Classical Set Theory, but we simply assumes these non constructively. @@ -642,18 +642,18 @@ Ordinals have the order and HOD has a natural order based on inclusion ( def / ∋ ). - def (od y) ( od→ord x ) + def (od y) ( & x ) An elements of HOD should be defined before the HOD, that is, an ordinal corresponding an elements have to be smaller than the corresponding ordinal of the containing OD. We also assumes subset is always smaller. This is necessary to make a limit of Power Set. - c<→o< : {x y : HOD } → def (od y) ( od→ord x ) → od→ord x o< od→ord y - ⊆→o≤ : {y z : HOD } → ({x : Ordinal} → def (od y) x → def (od z) x ) → od→ord y o< osuc (od→ord z) + c<→o< : {x y : HOD } → def (od y) ( & x ) → & x o< & y + ⊆→o≤ : {y z : HOD } → ({x : Ordinal} → def (od y) x → def (od z) x ) → & y o< osuc (& z) If wa assumes reverse order preservation, - o<→c< : {n : Level} {x y : Ordinal } → x o< y → def (ord→od y) x + o<→c< : {n : Level} {x y : Ordinal } → x o< y → def (* y) x ∀ x ∋ ∅ becomes true, which manes all OD becomes Ordinals in the model. @@ -707,7 +707,7 @@ data infinite-d : ( x : Ordinal ) → Set n where iφ : infinite-d o∅ isuc : {x : Ordinal } → infinite-d x → - infinite-d (od→ord ( Union (ord→od x , (ord→od x , ord→od x ) ) )) + infinite-d (& ( Union (* x , (* x , * x ) ) )) Union (x , ( x , x )) should be an direct successor of x, but we cannot prove it in our model. @@ -733,7 +733,7 @@ OD is an equation on Ordinals, we can simply write axiom of pair in the OD. _,_ : HOD → HOD → HOD - x , y = record { od = record { def = λ t → (t ≡ od→ord x ) ∨ ( t ≡ od→ord y ) } ; odmax = ? ; Agda Data Strucure + +as a data in Agda. Ex. + + data ord-pair : (p : Ordinal) → Set n where + pair : (x y : Ordinal ) → ord-pair ( & ( < * x , * y > ) ) + + ZFProduct : OD + ZFProduct = record { def = λ x → ord-pair x } + + pi1 : { p : Ordinal } → ord-pair p → Ordinal + pi1 ( pair x y) = x + + π1 : { p : HOD } → def ZFProduct (& p) → HOD + π1 lt = * (pi1 lt ) + + p-iso : { x : HOD } → (p : def ZFProduct (& x) ) → < π1 p , π2 p > ≡ x + p-iso {x} p = ord≡→≡ (op-iso p) + --HOD Ordrinal mapping @@ -871,8 +895,8 @@ The address of HOD can be larger at least it have to be larger than the content's address. We only have a relative ordering such as - pair-xx ¬a ¬b c with Oprev-p x + V1 x V0 | tri> ¬a ¬b c | yes p = Power ( V0 (Oprev.oprev p ) (subst (λ k → _ o< k) (Oprev.oprev=x p) <-osuc )) + V1 x V0 | tri> ¬a ¬b c | no ¬p = + record { od = record { def = λ y → (y o< x ) ∧ ((lt : y o< x ) → odef (V0 y lt) x ) } ; + odmax = x; ¬a ¬b c with Oprev-p x + L1 x L0 | tri> ¬a ¬b c | yes p = Df D ( L0 (Oprev.oprev p ) (subst (λ k → _ o< k) (Oprev.oprev=x p) <-osuc )) + L1 x L0 | tri> ¬a ¬b c | no ¬p = + record { od = record { def = λ y → (y o< x ) ∧ ((lt : y o< x ) → odef (L0 y lt) x ) } ; + odmax = x;