2014-11-28 10:20:52 -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-11-28 10:20:52 -05:00
|
|
|
|
Module: logic.axims.classical
|
|
|
|
|
Author: Leonardo de Moura
|
|
|
|
|
-/
|
2014-08-29 23:45:57 -04:00
|
|
|
|
|
2014-12-12 13:20:27 -08:00
|
|
|
|
import logic.connectives logic.quantifiers logic.cast algebra.relation
|
2014-07-31 18:40:09 -07:00
|
|
|
|
|
2014-10-01 17:51:17 -07:00
|
|
|
|
open eq.ops
|
2014-07-04 22:22:26 -07:00
|
|
|
|
|
2014-07-22 09:49:54 -07:00
|
|
|
|
axiom prop_complete (a : Prop) : a = true ∨ a = false
|
2014-07-04 22:22:26 -07:00
|
|
|
|
|
2014-08-29 23:45:57 -04:00
|
|
|
|
theorem cases (P : Prop → Prop) (H1 : P true) (H2 : P false) (a : Prop) : P a :=
|
2014-09-04 21:25:21 -07:00
|
|
|
|
or.elim (prop_complete a)
|
2014-07-28 19:58:57 -07:00
|
|
|
|
(assume Ht : a = true, Ht⁻¹ ▸ H1)
|
|
|
|
|
(assume Hf : a = false, Hf⁻¹ ▸ H2)
|
|
|
|
|
|
2014-08-29 23:45:57 -04:00
|
|
|
|
theorem cases_on (a : Prop) {P : Prop → Prop} (H1 : P true) (H2 : P false) : P a :=
|
|
|
|
|
cases P H1 H2 a
|
2014-08-19 19:32:44 -07:00
|
|
|
|
|
2014-08-29 23:45:57 -04:00
|
|
|
|
-- this supercedes the em in decidable
|
2014-07-28 19:58:57 -07:00
|
|
|
|
theorem em (a : Prop) : a ∨ ¬a :=
|
2014-09-04 21:25:21 -07:00
|
|
|
|
or.elim (prop_complete a)
|
2014-12-12 13:50:53 -08:00
|
|
|
|
(assume Ht : a = true, or.inl (of_eq_true Ht))
|
|
|
|
|
(assume Hf : a = false, or.inr (not_of_eq_false Hf))
|
2014-07-28 19:58:57 -07:00
|
|
|
|
|
|
|
|
|
theorem prop_complete_swapped (a : Prop) : a = false ∨ a = true :=
|
2014-08-29 23:45:57 -04:00
|
|
|
|
cases (λ x, x = false ∨ x = true)
|
2014-09-04 21:25:21 -07:00
|
|
|
|
(or.inr rfl)
|
|
|
|
|
(or.inl rfl)
|
2014-07-28 19:58:57 -07:00
|
|
|
|
a
|
|
|
|
|
|
|
|
|
|
theorem propext {a b : Prop} (Hab : a → b) (Hba : b → a) : a = b :=
|
2014-09-04 21:25:21 -07:00
|
|
|
|
or.elim (prop_complete a)
|
|
|
|
|
(assume Hat, or.elim (prop_complete b)
|
2014-07-28 19:58:57 -07:00
|
|
|
|
(assume Hbt, Hat ⬝ Hbt⁻¹)
|
2014-12-15 15:05:44 -05:00
|
|
|
|
(assume Hbf, false.elim (Hbf ▸ (Hab (of_eq_true Hat)))))
|
2014-09-04 21:25:21 -07:00
|
|
|
|
(assume Haf, or.elim (prop_complete b)
|
2014-12-15 15:05:44 -05:00
|
|
|
|
(assume Hbt, false.elim (Haf ▸ (Hba (of_eq_true Hbt))))
|
2014-07-28 19:58:57 -07:00
|
|
|
|
(assume Hbf, Haf ⬝ Hbf⁻¹))
|
|
|
|
|
|
2014-11-30 15:07:09 -08:00
|
|
|
|
theorem eq.of_iff {a b : Prop} (H : a ↔ b) : a = b :=
|
2014-09-04 21:25:21 -07:00
|
|
|
|
iff.elim (assume H1 H2, propext H1 H2) H
|
2014-07-28 19:58:57 -07:00
|
|
|
|
|
|
|
|
|
theorem iff_eq_eq {a b : Prop} : (a ↔ b) = (a = b) :=
|
|
|
|
|
propext
|
2014-11-30 15:07:09 -08:00
|
|
|
|
(assume H, eq.of_iff H)
|
|
|
|
|
(assume H, iff.of_eq H)
|
2014-07-28 19:58:57 -07:00
|
|
|
|
|
2014-09-03 16:00:38 -07:00
|
|
|
|
open relation
|
2014-11-28 10:20:52 -05:00
|
|
|
|
theorem iff_congruence [instance] (P : Prop → Prop) : is_congruence iff iff P :=
|
|
|
|
|
is_congruence.mk
|
2014-08-19 19:32:44 -07:00
|
|
|
|
(take (a b : Prop),
|
|
|
|
|
assume H : a ↔ b,
|
2014-11-30 15:07:09 -08:00
|
|
|
|
show P a ↔ P b, from iff.of_eq (eq.of_iff H ▸ eq.refl (P a)))
|