Mercurial > hg > Members > kono > Proof > ZF-in-agda
view zf.agda @ 13:8f3ff7bd2ff0
dead end
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Tue, 14 May 2019 00:23:47 +0900 |
parents | b531d2b417ad |
children |
line wrap: on
line source
module zf where open import Level record _∧_ {n m : Level} (A : Set n) ( B : Set m ) : Set (n ⊔ m) where field proj1 : A proj2 : B open _∧_ data _∨_ {n m : Level} (A : Set n) ( B : Set m ) : Set (n ⊔ m) where case1 : A → A ∨ B case2 : B → A ∨ B -- open import Relation.Binary.PropositionalEquality _⇔_ : {n : Level } → ( A B : Set n ) → Set n _⇔_ A B = ( A → B ) ∧ ( B → A ) open import Data.Empty open import Relation.Nullary open import Relation.Binary open import Relation.Binary.Core infixr 130 _∧_ infixr 140 _∨_ infixr 150 _⇔_ record Func {n m : Level } (ZFSet : Set n) (_≈_ : Rel ZFSet m) : Set (n ⊔ suc m) where field rel : Rel ZFSet m dom : ( y : ZFSet ) → ∀ { x : ZFSet } → rel x y fun-eq : { x y z : ZFSet } → ( rel x y ∧ rel x z ) → y ≈ z open Func record IsZF {n m : Level } (ZFSet : Set n) (_∋_ : ( A x : ZFSet ) → Set m) (_≈_ : Rel ZFSet m) (∅ : ZFSet) (_×_ : ( A B : ZFSet ) → ZFSet) (Union : ( A : ZFSet ) → ZFSet) (Power : ( A : ZFSet ) → ZFSet) (Select : ( ZFSet → Set m ) → ZFSet ) (Replace : ( ZFSet → ZFSet ) → ZFSet ) (infinite : ZFSet) : Set (suc (n ⊔ m)) where field isEquivalence : {A B : ZFSet} → IsEquivalence {n} {m} {ZFSet} _≈_ -- ∀ x ∀ y ∃ z(x ∈ z ∧ y ∈ z) pair : ( A B : ZFSet ) → ( (A × B) ∋ A ) ∧ ( (A × B) ∋ B ) -- ∀ X ∃ A∀ t(t ∈ A ⇔ ∃ x ∈ X(t ∈ x)) union→ : ( X x y : ZFSet ) → X ∋ x → x ∋ y → Union X ∋ y union← : ( X x y : ZFSet ) → Union X ∋ y → X ∋ x → x ∋ y _∈_ : ( A B : ZFSet ) → Set m A ∈ B = B ∋ A _⊆_ : ( A B : ZFSet ) → ∀{ x : ZFSet } → ∀{ A∋x : Set m } → Set m _⊆_ A B {x} {A∋x} = B ∋ x _∩_ : ( A B : ZFSet ) → ZFSet A ∩ B = Select ( λ x → ( A ∋ x ) ∧ ( B ∋ x ) ) _∪_ : ( A B : ZFSet ) → ZFSet A ∪ B = Select ( λ x → ( A ∋ x ) ∨ ( B ∋ x ) ) infixr 200 _∈_ infixr 230 _∩_ _∪_ infixr 220 _⊆_ field empty : ∀( x : ZFSet ) → ¬ ( ∅ ∋ x ) -- power : ∀ X ∃ A ∀ t ( t ∈ A ↔ t ⊆ X ) ) power→ : ∀( A t : ZFSet ) → Power A ∋ t → ∀ {x} {y} → _⊆_ t A {x} {y} power← : ∀( A t : ZFSet ) → ∀ {x} {y} → _⊆_ t A {x} {y} → Power A ∋ t -- extentionality : ∀ z ( z ∈ x ⇔ z ∈ y ) ⇒ ∀ w ( x ∈ w ⇔ y ∈ w ) extentionality : ( A B z : ZFSet ) → (( A ∋ z ) ⇔ (B ∋ z) ) → A ≈ B -- regularity : ∀ x ( x ≠ ∅ → ∃ y ∈ x ( y ∩ x = ∅ ) ) minimul : ZFSet → ZFSet regularity : ∀( x : ZFSet ) → ¬ (x ≈ ∅) → ( minimul x ∈ x ∧ ( minimul x ∩ x ≈ ∅ ) ) -- infinity : ∃ A ( ∅ ∈ A ∧ ∀ x ∈ A ( x ∪ { x } ∈ A ) ) infinity∅ : ∅ ∈ infinite infinity : ∀( x : ZFSet ) → x ∈ infinite → ( x ∪ Select ( λ y → x ≈ y )) ∈ infinite selection : { ψ : ZFSet → Set m } → ∀ ( y : ZFSet ) → ( y ∈ Select ψ ) → ψ y -- replacement : ∀ x ∀ y ∀ z ( ( ψ ( x , y ) ∧ ψ ( x , z ) ) → y = z ) → ∀ X ∃ A ∀ y ( y ∈ A ↔ ∃ x ∈ X ψ ( x , y ) ) replacement : {ψ : ZFSet → ZFSet} → ∀ ( x : ZFSet ) → ( ψ x ∈ Replace ψ ) record ZF {n m : Level } : Set (suc (n ⊔ m)) where infixr 210 _×_ infixl 200 _∋_ infixr 220 _≈_ field ZFSet : Set n _∋_ : ( A x : ZFSet ) → Set m _≈_ : ( A B : ZFSet ) → Set m -- ZF Set constructor ∅ : ZFSet _×_ : ( A B : ZFSet ) → ZFSet Union : ( A : ZFSet ) → ZFSet Power : ( A : ZFSet ) → ZFSet Select : ( ZFSet → Set m ) → ZFSet Replace : ( ZFSet → ZFSet ) → ZFSet infinite : ZFSet isZF : IsZF ZFSet _∋_ _≈_ ∅ _×_ Union Power Select Replace infinite module zf-exapmle {n m : Level } ( zf : ZF {m} {n} ) where _≈_ = ZF._≈_ zf ZFSet = ZF.ZFSet zf Select = ZF.Select zf ∅ = ZF.∅ zf _∩_ = ( IsZF._∩_ ) (ZF.isZF zf) _∋_ = ZF._∋_ zf replacement = IsZF.replacement ( ZF.isZF zf ) selection = IsZF.selection ( ZF.isZF zf ) minimul = IsZF.minimul ( ZF.isZF zf ) regularity = IsZF.regularity ( ZF.isZF zf ) -- russel : Select ( λ x → x ∋ x ) ≈ ∅ -- russel with Select ( λ x → x ∋ x ) -- ... | s = {!!} module constructible-set where open import Data.Nat renaming ( zero to Zero ; suc to Suc ; ℕ to Nat ) open import Relation.Binary.PropositionalEquality data Ordinal {n : Level } : Set n where Φ : {lv : Nat} → Ordinal {n} T-suc : {lv : Nat} → Ordinal {n} → Ordinal ℵ_ : (lv : Nat) → Ordinal olevel : {n : Level } → Ordinal {n} → Nat olevel (Φ {lv}) = lv olevel (T-suc {lv} x) = lv olevel (ℵ lv) = lv data _o<_ {n : Level } : Ordinal {n} → Ordinal {n} → Set n where l< : {x y : Ordinal {n} } → olevel x < olevel y → x o< y Φ< : {x : Ordinal {n} } → Φ {n} {olevel x} o< T-suc {n} {olevel x} x s< : {x : Ordinal {n} } → x o< T-suc {n} {olevel x} x ℵΦ< : {x : Ordinal {n} } → Φ {n} {olevel x} o< (ℵ (olevel x) ) ℵ< : {x : Ordinal {n} } → T-suc {n} {olevel x} x o< (ℵ (olevel x)) open import Data.Nat.Properties triO> : {n : Level } → {x y : Ordinal {n} } → olevel y < olevel x → x o< y → ⊥ triO> {n} {x} {y} y<x xo<y with <-cmp (olevel x ) (olevel y ) triO> {n} {x} {y} y<x xo<y | tri< a ¬b ¬c = ¬c y<x triO> {n} {x} {y} y<x xo<y | tri≈ ¬a b ¬c = ¬c y<x triO> {n} {x} {y} y<x (l< x₁) | tri> ¬a ¬b c = ¬a x₁ triO> {n} {Φ} {T-suc _} y<x Φ< | tri> ¬a ¬b c = ¬b refl triO> {n} {x} {T-suc x} y<x s< | tri> ¬a ¬b c = ¬b refl triO> {n} {Φ {u}} {ℵ u} y<x ℵΦ< | tri> ¬a ¬b c = ¬b refl triO> {n} {(T-suc _)} {ℵ u} y<x ℵ< | tri> ¬a ¬b c = ¬b refl nat< : { x y : Nat } → x ≡ y → x < y → ⊥ nat< {Zero} {Zero} refl () nat< {Suc x} {.(Suc x)} refl (s≤s t) = nat< {x} {x} refl t trio! : {n : Level } → {x : Ordinal {n} } → x o< x → ⊥ trio! {n} {x} (l< y) = nat< refl y triO : {n : Level } → Trichotomous _≡_ ( _o<_ {n} ) triO x y with <-cmp (olevel x ) (olevel y ) triO x y | tri< a ¬b ¬c = tri< (l< a) (λ x=y → ¬b (cong (λ z → olevel z) x=y ) ) ( triO> a ) triO x y | tri> ¬a ¬b c = tri> (triO> c) (λ x=y → ¬b (cong (λ z → olevel z) x=y ) ) (l< c) triO Φ Φ | tri≈ ¬a refl ¬c = tri≈ trio! refl trio! triO (ℵ lv) (ℵ lv) | tri≈ ¬a refl ¬c = tri≈ trio! refl trio! triO Φ (T-suc y) | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO Φ (ℵ lv) | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO (T-suc x) Φ | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO (T-suc x) (ℵ lv) | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO (ℵ lv) Φ | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO (ℵ lv) (T-suc y) | tri≈ ¬a refl ¬c = tri≈ {!!} {!!} {!!} triO (T-suc x) (T-suc y) | tri≈ ¬a refl ¬c with triO x y triO (T-suc x) (T-suc y) | tri≈ ¬a refl ¬c | tri< a ¬b ¬c₁ = tri< {!!} {!!} {!!} triO (T-suc x) (T-suc x) | tri≈ ¬a refl ¬c | tri≈ ¬a₁ refl ¬c₁ = tri≈ trio! refl trio! triO (T-suc x) (T-suc y) | tri≈ ¬a refl ¬c | tri> ¬a₁ ¬b c = {!!} max = Data.Nat._⊔_ maxα : {n : Level } → Ordinal {n} → Ordinal {n} → Ordinal {n} maxα x y with x o< y ... | t = {!!} -- X' = { x ∈ X | ψ x } ∪ X , Mα = ( ∪ (β < α) Mβ ) ' data Constructible {n : Level } ( α : Ordinal {n} ) : Set (suc n) where fsub : ( ψ : Ordinal {n} → Set n ) → Constructible α xself : Ordinal {n} → Constructible α record ConstructibleSet {n : Level } : Set (suc n) where field α : Ordinal {n} constructible : Constructible α open ConstructibleSet data _c∋_ {n : Level } : {α : Ordinal {n} } {α' : Ordinal {n} } → Constructible {n} α → Constructible {n} α' → Set n where c> : {α : Ordinal {n} } {α' : Ordinal {n} } (ta : Constructible {n} α ) ( tx : Constructible {n} α' ) → α' o< α → ta c∋ tx xself-fsub : {α : Ordinal {n} } (ta : Ordinal {n} ) ( ψ : Ordinal {n} → Set n ) → _c∋_ {n} {α} {α} (xself ta ) ( fsub ψ) fsub-fsub : {α : Ordinal {n} } ( ψ : Ordinal {n} → Set n ) ( ψ₁ : Ordinal {n} → Set n ) → ( ∀ ( x : Ordinal {n} ) → ψ x → ψ₁ x ) → _c∋_ {n} {α} {α} ( fsub ψ ) ( fsub ψ₁) _∋_ : {n : Level} → (ConstructibleSet {n}) → (ConstructibleSet {n} ) → Set n a ∋ x = constructible a c∋ constructible x data _c≈_ {n : Level } : {α : Ordinal {n} } {α' : Ordinal {n} } → Constructible {n} α → Constructible {n} α' → Set n where crefl : {α : Ordinal {n} } → _c≈_ {n} {α} {α} (xself α ) (xself α ) feq : {α : Ordinal {n} } → ( ψ : Ordinal {n} → Set n ) ( ψ₁ : Ordinal {n} → Set n ) → (∀ ( x : Ordinal {n} ) → ψ x ⇔ ψ₁ x ) → _c≈_ {n} {α} {α} ( fsub ψ ) ( fsub ψ₁) _≈_ : {n : Level} → (ConstructibleSet {n}) → (ConstructibleSet {n} ) → Set n a ≈ x = constructible a c≈ constructible x ConstructibleSet→ZF : {n : Level } → ZF {suc n} {n} ConstructibleSet→ZF {n} = record { ZFSet = ConstructibleSet ; _∋_ = _∋_ ; _≈_ = _≈_ ; ∅ = record { α = Φ ; constructible = xself Φ } ; _×_ = {!!} ; Union = {!!} ; Power = {!!} ; Select = {!!} ; Replace = {!!} ; infinite = {!!} ; isZF = {!!} } where