2014-08-07 18:36:44 +00:00
|
|
|
|
-- Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
2014-07-21 04:15:48 +00:00
|
|
|
|
-- Released under Apache 2.0 license as described in the file LICENSE.
|
2014-08-01 01:40:09 +00:00
|
|
|
|
-- Author: Leonardo de Moura
|
|
|
|
|
|
|
|
|
|
import logic.axioms.hilbert logic.axioms.funext
|
2014-10-02 00:51:17 +00:00
|
|
|
|
open eq.ops nonempty inhabited
|
2014-07-21 04:15:48 +00:00
|
|
|
|
|
|
|
|
|
-- Diaconescu’s theorem
|
|
|
|
|
-- Show that Excluded middle follows from
|
2014-07-22 16:43:18 +00:00
|
|
|
|
-- Hilbert's choice operator, function extensionality and Prop extensionality
|
2014-10-09 14:13:06 +00:00
|
|
|
|
context
|
2014-07-25 18:10:45 +00:00
|
|
|
|
hypothesis propext {a b : Prop} : (a → b) → (b → a) → a = b
|
2014-10-09 14:13:06 +00:00
|
|
|
|
parameter p : Prop
|
2014-07-21 04:15:48 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private definition u := epsilon (λx, x = true ∨ p)
|
2014-07-21 04:15:48 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private definition v := epsilon (λx, x = false ∨ p)
|
2014-07-21 04:15:48 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private lemma u_def : u = true ∨ p :=
|
2014-09-05 04:25:21 +00:00
|
|
|
|
epsilon_spec (exists_intro true (or.inl rfl))
|
2014-07-29 02:58:57 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private lemma v_def : v = false ∨ p :=
|
2014-09-05 04:25:21 +00:00
|
|
|
|
epsilon_spec (exists_intro false (or.inl rfl))
|
2014-07-29 02:58:57 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private lemma uv_implies_p : ¬(u = v) ∨ p :=
|
2014-09-05 04:25:21 +00:00
|
|
|
|
or.elim u_def
|
|
|
|
|
(assume Hut : u = true, or.elim v_def
|
2014-07-29 02:58:57 +00:00
|
|
|
|
(assume Hvf : v = false,
|
|
|
|
|
have Hne : ¬(u = v), from Hvf⁻¹ ▸ Hut⁻¹ ▸ true_ne_false,
|
2014-09-05 04:25:21 +00:00
|
|
|
|
or.inl Hne)
|
|
|
|
|
(assume Hp : p, or.inr Hp))
|
|
|
|
|
(assume Hp : p, or.inr Hp)
|
2014-07-29 02:58:57 +00:00
|
|
|
|
|
2014-09-19 21:30:02 +00:00
|
|
|
|
private lemma p_implies_uv : p → u = v :=
|
2014-07-29 02:58:57 +00:00
|
|
|
|
assume Hp : p,
|
|
|
|
|
have Hpred : (λ x, x = true ∨ p) = (λ x, x = false ∨ p), from
|
|
|
|
|
funext (take x : Prop,
|
|
|
|
|
have Hl : (x = true ∨ p) → (x = false ∨ p), from
|
2014-09-05 04:25:21 +00:00
|
|
|
|
assume A, or.inr Hp,
|
2014-07-29 02:58:57 +00:00
|
|
|
|
have Hr : (x = false ∨ p) → (x = true ∨ p), from
|
2014-09-05 04:25:21 +00:00
|
|
|
|
assume A, or.inr Hp,
|
2014-07-29 02:58:57 +00:00
|
|
|
|
show (x = true ∨ p) = (x = false ∨ p), from
|
|
|
|
|
propext Hl Hr),
|
|
|
|
|
show u = v, from
|
2014-09-04 23:36:06 +00:00
|
|
|
|
Hpred ▸ (eq.refl (epsilon (λ x, x = true ∨ p)))
|
2014-07-29 02:58:57 +00:00
|
|
|
|
|
|
|
|
|
theorem em : p ∨ ¬p :=
|
2014-08-04 05:58:12 +00:00
|
|
|
|
have H : ¬(u = v) → ¬p, from mt p_implies_uv,
|
2014-09-05 04:25:21 +00:00
|
|
|
|
or.elim uv_implies_p
|
|
|
|
|
(assume Hne : ¬(u = v), or.inr (H Hne))
|
|
|
|
|
(assume Hp : p, or.inl Hp)
|
2014-07-21 04:15:48 +00:00
|
|
|
|
end
|