{-# OPTIONS --cubical-compatible --safe #-}
module zf where
open import Level
open import logic
open import Relation.Nullary
open import Relation.Binary hiding (_⇔_)
open import Data.Empty
record ZPred {n m : Level } (ZFSet : Set n) (_∋_ : ( A x : ZFSet ) → Set m) (_≈_ : Rel ZFSet m)
(ψ : ZFSet → Set m ) : Set (suc (n ⊔ suc m)) where
field
ψ-cong : (x y : ZFSet) → x ≈ y → ψ x ⇔ ψ y
record ZFunc {n m : Level } (ZFSet : Set n) (_∋_ : ( A x : ZFSet ) → Set m) (_≈_ : Rel ZFSet m)
(ψ : ZFSet → ZFSet ) : Set (suc (n ⊔ suc m)) where
field
cod : ZFSet
cod∋ψ : (x : ZFSet) → cod ∋ ψ x
ψ-cong : (x y : ZFSet) → x ≈ y → ψ x ≈ ψ y
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 : (X : ZFSet ) → ( ψ : (x : ZFSet ) → Set m ) → ZPred ZFSet _∋_ _≈_ ψ → ZFSet )
(Replace : ZFSet → ( φ : ZFSet → ZFSet ) → ZFunc ZFSet _∋_ _≈_ φ → ZFSet )
(infinite : ZFSet)
: Set (suc (n ⊔ suc m)) where
field
isEquivalence : IsEquivalence {n} {m} {ZFSet} _≈_
pair→ : ( x y t : ZFSet ) → (x , y) ∋ t → ( t ≈ x ) ∨ ( t ≈ y )
pair← : ( x y t : ZFSet ) → ( t ≈ x ) ∨ ( t ≈ y ) → (x , y) ∋ t
union→ : ( X z u : ZFSet ) → ( X ∋ u ) ∧ (u ∋ z ) → Union X ∋ z
union← : ( X z : ZFSet ) → (X∋z : Union X ∋ z ) → ¬ ( (u : ZFSet ) → ¬ ((X ∋ u) ∧ (u ∋ z )))
_∈_ : ( A B : ZFSet ) → Set m
A ∈ B = B ∋ A
_⊆_ : ( A B : ZFSet ) → ∀{ x : ZFSet } → Set m
_⊆_ A B {x} = A ∋ x → B ∋ x
_∪_ : ( A B : ZFSet ) → ZFSet
A ∪ B = Union (A , B)
{_} : ZFSet → ZFSet
{ x } = ( x , x )
infixr 200 _∈_
infixr 230 _∪_
infixr 220 _⊆_
field
empty : ∀( x : ZFSet ) → ¬ ( ∅ ∋ x )
power→ : ∀( A t : ZFSet ) → Power A ∋ t → ∀ {x} → t ∋ x → A ∋ x
power← : ∀( A t : ZFSet ) → ( ∀ {x} → _⊆_ t A {x}) → Power A ∋ t
extensionality : { A B w : ZFSet } → ( (z : ZFSet) → ( A ∋ z ) ⇔ (B ∋ z) ) → ( A ∈ w ⇔ B ∈ w )
ε-induction : { ψ : ZFSet → Set (suc m Level.⊔ n)}
→ ( {x : ZFSet } → ({ y : ZFSet } → x ∋ y → ψ y ) → ψ x )
→ (x : ZFSet ) → ψ x
infinity∅ : ∅ ∈ infinite
infinity : ∀( x : ZFSet ) → x ∈ infinite → ( x ∪ { x }) ∈ infinite
selection : { ψ : ZFSet → Set m } → { zψ : ZPred ZFSet _∋_ _≈_ ψ } → ∀ { X y : ZFSet }
→ ( ( y ∈ X ) ∧ ψ y ) ⇔ (y ∈ Select X ψ zψ )
replacement← : {ψ : ZFSet → ZFSet} → { zψ : ZFunc ZFSet _∋_ _≈_ ψ } → ∀ ( X x : ZFSet ) → x ∈ X → ψ x ∈ Replace X ψ zψ
replacement→ : {ψ : ZFSet → ZFSet} → { zψ : ZFunc ZFSet _∋_ _≈_ ψ } → ∀ ( X x : ZFSet )
→ ( lt : x ∈ Replace X ψ zψ) → ¬ ( ∀ (y : ZFSet) → ¬ ( x ≈ ψ y ) )
record ZF {n m : Level } : Set (suc (n ⊔ suc m)) where
infixr 210 _,_
infixl 200 _∋_
infixr 220 _≈_
field
ZFSet : Set n
_∋_ : ( A x : ZFSet ) → Set m
_≈_ : ( A B : ZFSet ) → Set m
∅ : ZFSet
_,_ : ( A B : ZFSet ) → ZFSet
Union : ( A : ZFSet ) → ZFSet
Power : ( A : ZFSet ) → ZFSet
Select : (X : ZFSet ) → ( φ : (x : ZFSet ) → Set m ) → ( zψ : ZPred ZFSet _∋_ _≈_ φ ) → ZFSet
Replace : ZFSet → ( φ : ZFSet → ZFSet ) → ( zψ : ZFunc ZFSet _∋_ _≈_ φ ) → ZFSet
infinite : ZFSet
isZF : IsZF ZFSet _∋_ _≈_ ∅ _,_ Union Power Select Replace infinite