add big_union

This commit is contained in:
Dan Frumin 2019-06-12 14:09:12 +02:00
parent 0578569c09
commit 3da73646d1
1 changed files with 27 additions and 3 deletions

30
czf.v
View File

@ -230,7 +230,28 @@ Proof.
Qed. Qed.
(** Union *) (** Union *)
(* TODO: need big union operation *) Definition big_union (a : V) : V.
Proof.
destruct a as [A f].
refine (sup { x : A & ind (f x) } _).
intros [x y]. apply (branch (f x) y).
Defined.
Theorem CZF_union (a : V) :
forall (x : V), x big_union a
exists (z : V), (x z z a).
Proof.
intros x. split.
- destruct a as [A f].
intros [[a b] Hx]. simpl in *.
exists (f a). split.
+ rewrite Hx. exists b. reflexivity.
+ exists a. reflexivity.
- intros [z [[β Hx] [α Hz]]].
destruct a as [A f]. simpl in *.
assert ({x0 : A & ind (f x0)}).
exists α.
Abort.
(** Empty set *) (** Empty set *)
Theorem CZF_empty : Theorem CZF_empty :
@ -263,7 +284,7 @@ Qed.
Definition sep (a : V) (ϕ : V Prop) : V. Definition sep (a : V) (ϕ : V Prop) : V.
Proof. Proof.
destruct a as [A f]. destruct a as [A f].
refine (sup (sigT (λ (x:A), ϕ (f x))) _). refine (sup (sig (λ (x:A), ϕ (f x))) _).
intros [x ?]. exact (f x). intros [x ?]. exact (f x).
Defined. Defined.
@ -276,7 +297,7 @@ Proof.
rewrite Hx. split; [exists x|]; eauto. rewrite Hx. split; [exists x|]; eauto.
- intros [[x Hx] ]. simpl in *. - intros [[x Hx] ]. simpl in *.
rewrite Hx in . rewrite Hx in .
exists (existT x ). assumption. exists (exist _ x ). assumption.
Qed. Qed.
(** Collection *) (** Collection *)
@ -327,3 +348,6 @@ Proof.
set (Hϕ':= (f y) (ex_intro (λ z, f y f z) y (reflexivity _))). set (Hϕ':= (f y) (ex_intro (λ z, f y f z) y (reflexivity _))).
apply (proj2_sig Hϕ'). apply (proj2_sig Hϕ').
Qed. Qed.
(** Subset collection *)
(* ... *)