# HG changeset patch # User Shinji KONO # Date 1589010100 -32400 # Node ID 197e0b3d39dcabd946dc270d682760de34e5b16c # Parent bfb5e807718b7d98d45163ab33cfa918722a0965 ... diff -r bfb5e807718b -r 197e0b3d39dc LEMC.agda --- a/LEMC.agda Sat May 09 09:40:18 2020 +0900 +++ b/LEMC.agda Sat May 09 16:41:40 2020 +0900 @@ -84,4 +84,17 @@ eq→ = λ {x} lt → ⊥-elim (nn x (def→o< lt) lt) ; eq← = λ {x} lt → ⊥-elim ( ¬x<0 lt ) } + minimal-choice : (X : OD ) → ¬ (X == od∅) → choiced X + minimal-choice X ne = choice-func {!!} ne + minimal : (x : OD ) → ¬ (x == od∅ ) → OD + minimal x not = a-choice (minimal-choice x not ) + -- this should be ¬ (x == od∅ )→ ∃ ox → x ∋ Ord ox ( minimum of x ) + x∋minimal : (x : OD ) → ( ne : ¬ (x == od∅ ) ) → def x ( od→ord ( minimal x ne ) ) + x∋minimal x ne = is-in (minimal-choice x ne ) + -- minimality (may proved by ε-induction ) + minimal-1 : (x : OD ) → ( ne : ¬ (x == od∅ ) ) → (y : OD ) → ¬ ( def (minimal x ne) (od→ord y)) ∧ (def x (od→ord y) ) + minimal-1 x ne y = {!!} + + + diff -r bfb5e807718b -r 197e0b3d39dc ODC.agda --- a/ODC.agda Sat May 09 09:40:18 2020 +0900 +++ b/ODC.agda Sat May 09 16:41:40 2020 +0900 @@ -94,47 +94,3 @@ choice : (X : OD ) → {A : OD } → ( X∋A : X ∋ A ) → (not : ¬ ( A == od∅ )) → A ∋ choice-func X not X∋A choice X {A} X∋A not = x∋minimal A not - --- With assuption of OD is ordered, p ∨ ( ¬ p ) <=> axiom of choice - --- - record choiced ( X : OD) : Set (suc n) where - field - a-choice : OD - is-in : X ∋ a-choice - - choice-func' : (X : OD ) → (p∨¬p : ( p : Set (suc n)) → p ∨ ( ¬ p )) → ¬ ( X == od∅ ) → choiced X - choice-func' X p∨¬p not = have_to_find where - ψ : ( ox : Ordinal ) → Set (suc n) - ψ ox = (( x : Ordinal ) → x o< ox → ( ¬ def X x )) ∨ choiced X - lemma-ord : ( ox : Ordinal ) → ψ ox - lemma-ord ox = TransFinite {ψ} induction ox where - ∋-p : (A x : OD ) → Dec ( A ∋ x ) - ∋-p A x with p∨¬p (Lift (suc n) ( A ∋ x )) -- LEM - ∋-p A x | case1 (lift t) = yes t - ∋-p A x | case2 t = no (λ x → t (lift x )) - ∀-imply-or : {A : Ordinal → Set n } {B : Set (suc n) } - → ((x : Ordinal ) → A x ∨ B) → ((x : Ordinal ) → A x) ∨ B - ∀-imply-or {A} {B} ∀AB with p∨¬p (Lift ( suc n ) ((x : Ordinal ) → A x)) -- LEM - ∀-imply-or {A} {B} ∀AB | case1 (lift t) = case1 t - ∀-imply-or {A} {B} ∀AB | case2 x = case2 (lemma (λ not → x (lift not ))) where - lemma : ¬ ((x : Ordinal ) → A x) → B - lemma not with p∨¬p B - lemma not | case1 b = b - lemma not | case2 ¬b = ⊥-elim (not (λ x → dont-orb (∀AB x) ¬b )) - induction : (x : Ordinal) → ((y : Ordinal) → y o< x → ψ y) → ψ x - induction x prev with ∋-p X ( ord→od x) - ... | yes p = case2 ( record { a-choice = ord→od x ; is-in = p } ) - ... | no ¬p = lemma where - lemma1 : (y : Ordinal) → (y o< x → def X y → ⊥) ∨ choiced X - lemma1 y with ∋-p X (ord→od y) - lemma1 y | yes y Shinji KONO
-

Programming Mathematics

+

ZF in Agda

+ +
+    zf.agda            axiom of ZF
+    zfc.agda           axiom of choice
+    Ordinals.agda      axiom of Ordinals
+    ordinal.agda       countable model of Ordinals
+    OD.agda            model of ZF based on Ordinal Definable Set with assumptions
+    ODC.agda           Law of exclude middle from axiom of choice assumptions
+    LEMC.agda          model of choice with assumption of the Law of exclude middle 
+    OPair.agda         ordered pair on OD
+    BAlgbra.agda       Boolean algebra on OD (not yet done)
+    filter.agda        Filter on OD (not yet done)
+    cardinal.agda      Caedinal number on OD (not yet done)
+    logic.agda         some basics on logic
+    nat.agda           some basics on Nat
+
+
+ +
+

Programming Mathematics

+ +

Programming is processing data structure with λ terms.

We are going to handle Mathematics in intuitionistic logic with λ terms. @@ -49,7 +71,7 @@


-

Target

+

Target

    Describe ZF axioms in Agda
@@ -67,7 +89,7 @@
 


-

Why Set Theory

+

Why Set Theory

If we can formulate Set theory, it suppose to work on any mathematical theory.

Set Theory is a difficult point for beginners especially axiom of choice. @@ -80,7 +102,7 @@


-

Agda and Intuitionistic Logic

+

Agda and Intuitionistic Logic

Curry Howard Isomorphism

@@ -102,7 +124,7 @@


-

Introduction of Agda

+

Introduction of Agda

A length of a list of type A.

@@ -121,7 +143,7 @@


-

data ( Sum type )

+

data ( Sum type )

A data type which as exclusive multiple constructors. A similar one as union in C or case class in Scala.

@@ -148,7 +170,7 @@


-

A → B means "A implies B"

+

A → B means "A implies B"

In Agda, a type can be a value of a variable, which is usually called dependent type. @@ -172,7 +194,7 @@


-

introduction と elimination

+

introduction と elimination

For a logical operator, there are two types of inference, an introduction and an elimination.

@@ -220,7 +242,7 @@


-

To prove A → B

+

To prove A → B

Make a left type as an argument. (intros in Coq)

@@ -236,7 +258,7 @@


-

A ∧ B

+

A ∧ B

Well known conjunction's introduction and elimination is as follow.

@@ -250,7 +272,7 @@


-

record

+

record

    record _∧_ A B : Set
@@ -286,7 +308,7 @@
 


-

Mathematical structure

+

Mathematical structure

We have types of elements and the relationship in a mathematical structure.

@@ -317,7 +339,7 @@


-

A Model and a theory

+

A Model and a theory

Agda record is a type, so we can write it in the argument, but is it really exists?

If we have a value of the record, it simply exists, that is, we need to create all the existence @@ -334,7 +356,7 @@


-

postulate と module

+

postulate と module

Agda proofs are separated by modules, which are large records.

postulates are assumptions. We can assume a type without proofs. @@ -357,7 +379,7 @@


-

A ∨ B

+

A ∨ B

     data _∨_ (A B : Set) : Set where
@@ -386,7 +408,7 @@
 


-

Negation

+

Negation

        ⊥
@@ -422,7 +444,7 @@
 

-

Equality

+

Equality

All the value in Agda are terms. If we have the same normalized form, two terms are equal. @@ -456,7 +478,7 @@


-

Equivalence relation

+

Equivalence relation

@@ -473,7 +495,7 @@


-

Ordering

+

Ordering

Relation is a predicate on two value which has a same type. @@ -494,7 +516,7 @@


-

Quantifier

+

Quantifier

Handling quantifier in an intuitionistic logic requires special cares. @@ -518,7 +540,7 @@


-

Can we do math in this way?

+

Can we do math in this way?

Yes, we can. Actually we have Principia Mathematica by Russell and Whitehead (with out computer support).

In some sense, this story is a reprinting of the work, (but Principia Mathematica has a different formulation than ZF). @@ -531,7 +553,7 @@


-

Things which Agda cannot prove

+

Things which Agda cannot prove

The infamous Internal Parametricity is a limitation of Agda, it cannot prove so called Free Theorem, which @@ -561,7 +583,7 @@


-

Classical story of ZF Set Theory

+

Classical story of ZF Set Theory

Assuming ZF, constructing a model of ZF is a flow of classical Set Theory, which leads @@ -577,7 +599,7 @@


-

Ordinals

+

Ordinals

Ordinals are our intuition of infinite things, which has ∅ and orders on the things. It also has a successor osuc.

@@ -597,7 +619,7 @@


-

Axiom of Ordinals

+

Axiom of Ordinals

Properties of infinite things. We request a transfinite induction, which states that if some properties are satisfied below all possible ordinals, the properties are true on all ordinals. @@ -625,7 +647,7 @@
-

Concrete Ordinals

+

Concrete Ordinals

We can define a list like structure with level, which is a kind of two dimensional infinite array. @@ -658,7 +680,7 @@


-

Model of Ordinals

+

Model of Ordinals

It is easy to show OrdinalD and its order satisfies the axioms of Ordinals. @@ -667,7 +689,7 @@


-

Debugging axioms using Model

+

Debugging axioms using Model

Whether axiom is correct or not can be checked by a validity on a mode.

If not, we may fix the axioms or the model, such as the definitions of the order. @@ -676,7 +698,7 @@


-

Countable Ordinals can contains uncountable set?

+

Countable Ordinals can contains uncountable set?

Yes, the ordinals contains any level of infinite Set in the axioms.

If we handle real-number in the model, only countable number of real-number is used. @@ -694,7 +716,7 @@


-

What is Set

+

What is Set

The word Set in Agda is not a Set of ZF Set, but it is a type (why it is named Set?).

From naive point view, a set i a list, but in Agda, elements have all the same type. @@ -704,7 +726,7 @@


-

We don't ask the contents of Set. It can be anything.

+

We don't ask the contents of Set. It can be anything.

From empty set φ, we can think a set contains a φ, and a pair of φ and the set, and so on, and all of them, and again we repeat this.

@@ -722,7 +744,7 @@


-

Ordinal Definable Set

+

Ordinal Definable Set

We can define a sbuset of Ordinals using predicates. What is a subset?

@@ -751,7 +773,7 @@


-

∋ in OD

+

∋ in OD

OD is a predicate on Ordinals and it does not contains OD directly. If we have a mapping

@@ -778,7 +800,7 @@


-

1 to 1 mapping between an OD and an Ordinal

+

1 to 1 mapping between an OD and an Ordinal

@@ -800,7 +822,7 @@


-

Order preserving in the mapping of OD and Ordinal

+

Order preserving in the mapping of OD and Ordinal

Ordinals have the order and OD has a natural order based on inclusion ( def / ∋ ).

@@ -833,7 +855,7 @@


-

ISO

+

ISO

It also requires isomorphisms,

@@ -844,7 +866,7 @@


-

Various Sets

+

Various Sets

In classical Set Theory, there is a hierarchy call L, which can be defined by a predicate. @@ -860,7 +882,7 @@


-

Fixes on ZF to intuitionistic logic

+

Fixes on ZF to intuitionistic logic

We use ODs as Sets in ZF, and defines record ZF, that is, we have to define @@ -878,10 +900,10 @@


-

Pure logical axioms

+

Pure logical axioms

-   empty, pair, select, ε-inductioninfinity
+   empty, pair, select, ε-induction??infinity
 
 
These are logical relations among OD. @@ -913,7 +935,7 @@


-

Axiom of Pair

+

Axiom of Pair

In the Tanaka's book, axiom of pair is as follows.

@@ -940,7 +962,7 @@


-

pair in OD

+

pair in OD

OD is an equation on Ordinals, we can simply write axiom of pair in the OD.

@@ -953,7 +975,7 @@


-

Validity of Axiom of Pair

+

Validity of Axiom of Pair

Assuming ZFSet is OD, we are going to prove pair→ .

@@ -994,7 +1016,7 @@


-

Equality of OD and Axiom of Extensionality

+

Equality of OD and Axiom of Extensionality

OD is defined by a predicates, if we compares normal form of the predicates, even if it contains the same elements, it may be different, which is no good as an equality of Sets. @@ -1056,7 +1078,7 @@
-

Validity of Axiom of Extensionality

+

Validity of Axiom of Extensionality

If we can derive (w ∋ A) ⇔ (w ∋ B) from A == B, the axiom becomes valid, but it seems impossible, so we assumes @@ -1079,7 +1101,7 @@


-

Non constructive assumptions so far

+

Non constructive assumptions so far

We have correspondence between OD and Ordinals and one directional order preserving.

We also have equality assumption. @@ -1096,7 +1118,7 @@


-

Axiom which have negation form

+

Axiom which have negation form

@@ -1120,7 +1142,7 @@


-

Union

+

Union

The original form of the Axiom of Union is

@@ -1172,7 +1194,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,

@@ -1216,7 +1238,7 @@


-

Validity of Power Set Axiom

+

Validity of Power Set Axiom

The original Power Set Axiom is this.

@@ -1307,7 +1329,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 @@ -1354,7 +1376,7 @@


-

Axiom of choice and Law of Excluded Middle

+

Axiom of choice and Law of Excluded Middle

In our model, since OD 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. @@ -1374,13 +1396,13 @@


-

Relation-ship among ZF axiom

+

Relation-ship among ZF axiom


-

Non constructive assumption in our model

+

Non constructive assumption in our model

mapping between OD and Ordinals

@@ -1418,7 +1440,7 @@


-

So it this correct?

+

So it this correct?

Our axiom are syntactically the same in the text book, but negations are slightly different. @@ -1438,7 +1460,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.

@@ -1449,7 +1471,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.

@@ -1467,7 +1489,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 @@ -1485,7 +1507,7 @@


-

Filter

+

Filter

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


-

Programming Mathematics

+

Programming Mathematics

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

@@ -1533,7 +1555,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 @@ -1553,67 +1575,68 @@

-
Shinji KONO / Sat Jan 11 20:04:01 2020 +
Shinji KONO / Sat May 9 16:41:10 2020 diff -r bfb5e807718b -r 197e0b3d39dc zf-in-agda.ind --- a/zf-in-agda.ind Sat May 09 09:40:18 2020 +0900 +++ b/zf-in-agda.ind Sat May 09 16:41:40 2020 +0900 @@ -2,6 +2,24 @@ --author: Shinji KONO +--ZF in Agda + + zf.agda axiom of ZF + zfc.agda axiom of choice + Ordinals.agda axiom of Ordinals + ordinal.agda countable model of Ordinals + OD.agda model of ZF based on Ordinal Definable Set with assumptions + ODC.agda Law of exclude middle from axiom of choice assumptions + LEMC.agda model of choice with assumption of the Law of exclude middle + OPair.agda ordered pair on OD + + BAlgbra.agda Boolean algebra on OD (not yet done) + filter.agda Filter on OD (not yet done) + cardinal.agda Caedinal number on OD (not yet done) + + logic.agda some basics on logic + nat.agda some basics on Nat + --Programming Mathematics Programming is processing data structure with λ terms. @@ -620,7 +638,7 @@ --Pure logical axioms - empty, pair, select, ε-inductioninfinity + empty, pair, select, ε-induction??infinity These are logical relations among OD.