2014-12-22 14:54:01 -05:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
2014-07-31 18:40:09 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
Module: logic.axioms.hilbert
|
|
|
|
Authors: Leonardo de Moura, Jeremy Avigad
|
|
|
|
|
|
|
|
Follows Coq.Logic.ClassicalEpsilon (but our definition of "inhabited" is the constructive one).
|
|
|
|
-/
|
2014-08-22 16:36:47 -07:00
|
|
|
|
2014-10-05 10:50:13 -07:00
|
|
|
import logic.quantifiers
|
2014-08-14 20:12:54 -07:00
|
|
|
import data.subtype data.sum
|
2014-07-13 01:39:35 +01:00
|
|
|
|
2014-09-03 16:00:38 -07:00
|
|
|
open subtype inhabited nonempty
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
/- the axiom -/
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
-- In the presence of classical logic, we could prove this from a weaker statement:
|
|
|
|
-- axiom indefinite_description {A : Type} {P : A->Prop} (H : ∃x, P x) : {x : A, P x}
|
2014-08-14 20:12:54 -07:00
|
|
|
axiom strong_indefinite_description {A : Type} (P : A → Prop) (H : nonempty A) :
|
2014-11-16 14:19:35 -08:00
|
|
|
{ x | (∃y : A, P y) → P x}
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
theorem exists_true_of_nonempty {A : Type} (H : nonempty A) : ∃x : A, true :=
|
2014-12-15 19:05:03 -08:00
|
|
|
nonempty.elim H (take x, exists.intro x trivial)
|
2014-08-15 08:43:52 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
theorem inhabited_of_nonempty {A : Type} (H : nonempty A) : inhabited A :=
|
2014-11-16 14:19:35 -08:00
|
|
|
let u : {x | (∃y : A, true) → true} := strong_indefinite_description (λa, true) H in
|
2014-09-04 16:36:06 -07:00
|
|
|
inhabited.mk (elt_of u)
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
theorem inhabited_of_exists {A : Type} {P : A → Prop} (H : ∃x, P x) : inhabited A :=
|
|
|
|
inhabited_of_nonempty (obtain w Hw, from H, nonempty.intro w)
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
/- the Hilbert epsilon function -/
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-10-12 13:06:00 -07:00
|
|
|
opaque definition epsilon {A : Type} [H : nonempty A] (P : A → Prop) : A :=
|
2014-11-16 14:19:35 -08:00
|
|
|
let u : {x | (∃y, P y) → P x} :=
|
2014-08-15 08:43:52 -07:00
|
|
|
strong_indefinite_description P H in
|
2014-08-14 20:12:54 -07:00
|
|
|
elt_of u
|
|
|
|
|
2014-08-15 08:43:52 -07:00
|
|
|
theorem epsilon_spec_aux {A : Type} (H : nonempty A) (P : A → Prop) (Hex : ∃y, P y) :
|
2014-08-14 20:12:54 -07:00
|
|
|
P (@epsilon A H P) :=
|
2014-11-16 14:19:35 -08:00
|
|
|
let u : {x | (∃y, P y) → P x} :=
|
2014-08-15 08:43:52 -07:00
|
|
|
strong_indefinite_description P H in
|
2014-08-14 20:12:54 -07:00
|
|
|
has_property u Hex
|
|
|
|
|
|
|
|
theorem epsilon_spec {A : Type} {P : A → Prop} (Hex : ∃y, P y) :
|
2014-12-15 16:13:04 -05:00
|
|
|
P (@epsilon A (nonempty_of_exists Hex) P) :=
|
|
|
|
epsilon_spec_aux (nonempty_of_exists Hex) P Hex
|
2014-07-13 01:39:35 +01:00
|
|
|
|
2014-09-04 16:36:06 -07:00
|
|
|
theorem epsilon_singleton {A : Type} (a : A) : @epsilon A (nonempty.intro a) (λx, x = a) = a :=
|
2014-12-15 19:05:03 -08:00
|
|
|
epsilon_spec (exists.intro a (eq.refl a))
|
2014-08-14 20:12:54 -07:00
|
|
|
|
2014-12-22 14:54:01 -05:00
|
|
|
/- the axiom of choice -/
|
2014-07-13 01:39:35 +01:00
|
|
|
|
2014-08-14 20:12:54 -07:00
|
|
|
theorem axiom_of_choice {A : Type} {B : A → Type} {R : Πx, B x → Prop} (H : ∀x, ∃y, R x y) :
|
|
|
|
∃f, ∀x, R x (f x) :=
|
2014-12-15 16:13:04 -05:00
|
|
|
let f := λx, @epsilon _ (nonempty_of_exists (H x)) (λy, R x y),
|
2014-08-21 18:24:22 -07:00
|
|
|
H := take x, epsilon_spec (H x)
|
2014-12-15 19:05:03 -08:00
|
|
|
in exists.intro f H
|
2014-07-13 01:39:35 +01:00
|
|
|
|
2014-08-14 20:12:54 -07:00
|
|
|
theorem skolem {A : Type} {B : A → Type} {P : Πx, B x → Prop} :
|
|
|
|
(∀x, ∃y, P x y) ↔ ∃f, (∀x, P x (f x)) :=
|
2014-09-04 21:25:21 -07:00
|
|
|
iff.intro
|
2014-08-14 20:12:54 -07:00
|
|
|
(assume H : (∀x, ∃y, P x y), axiom_of_choice H)
|
|
|
|
(assume H : (∃f, (∀x, P x (f x))),
|
|
|
|
take x, obtain (fw : ∀x, B x) (Hw : ∀x, P x (fw x)), from H,
|
2014-12-15 19:05:03 -08:00
|
|
|
exists.intro (fw x) (Hw x))
|