From ebf34f2fe938a59c941b613eae3526408f4ba7d0 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Thu, 24 Jul 2014 22:14:15 -0700 Subject: [PATCH] refactor(library/standard): mark 'not' as transparent Signed-off-by: Leonardo de Moura --- library/standard/bool.lean | 4 +-- library/standard/classical.lean | 16 ++++++------ library/standard/decidable.lean | 7 +++-- library/standard/logic.lean | 4 +-- library/standard/nat.lean | 45 ++++++++++++++------------------- 5 files changed, 34 insertions(+), 42 deletions(-) diff --git a/library/standard/bool.lean b/library/standard/bool.lean index 3675b9640..40aa128c0 100644 --- a/library/standard/bool.lean +++ b/library/standard/bool.lean @@ -29,11 +29,11 @@ theorem cond_b1 {A : Type} (t e : A) : cond '1 t e = t := refl (cond '1 t e) theorem b0_ne_b1 : ¬ '0 = '1 -:= not_intro (assume H : '0 = '1, absurd +:= assume H : '0 = '1, absurd (calc true = cond '1 true false : symm (cond_b1 _ _) ... = cond '0 true false : {symm H} ... = false : cond_b0 _ _) - true_ne_false) + true_ne_false definition bor (a b : bool) := bool_rec (bool_rec '0 '1 b) '1 a diff --git a/library/standard/classical.lean b/library/standard/classical.lean index 71cd9621c..788a138cb 100644 --- a/library/standard/classical.lean +++ b/library/standard/classical.lean @@ -23,14 +23,14 @@ theorem prop_complete_swapped (a : Prop) : a = false ∨ a = true theorem not_true : (¬true) = false := have aux : ¬ (¬true) = true, from - not_intro (assume H : (¬true) = true, - absurd_not_true (subst (symm H) trivial)), + assume H : (¬true) = true, + absurd_not_true (subst (symm H) trivial), resolve_right (prop_complete (¬true)) aux theorem not_false : (¬false) = true := have aux : ¬ (¬false) = false, from - not_intro (assume H : (¬false) = false, - subst H not_false_trivial), + assume H : (¬false) = false, + subst H not_false_trivial, resolve_right (prop_complete_swapped (¬ false)) aux theorem not_not_eq (a : Prop) : (¬¬a) = a @@ -89,10 +89,10 @@ theorem not_or (a b : Prop) : (¬ (a ∨ b)) = (¬ a ∧ ¬ b) (assume Hna, or_elim (em b) (assume Hb, absurd_elim (¬ a ∧ ¬ b) (or_intro_right a Hb) H) (assume Hnb, and_intro Hna Hnb))) - (assume (H : ¬ a ∧ ¬ b), not_intro (assume (N : a ∨ b), + (assume (H : ¬ a ∧ ¬ b) (N : a ∨ b), or_elim N (assume Ha, absurd Ha (and_elim_left H)) - (assume Hb, absurd Hb (and_elim_right H)))) + (assume Hb, absurd Hb (and_elim_right H))) theorem not_and (a b : Prop) : (¬ (a ∧ b)) = (¬ a ∨ ¬ b) := propext @@ -101,10 +101,10 @@ theorem not_and (a b : Prop) : (¬ (a ∧ b)) = (¬ a ∨ ¬ b) (assume Hb, absurd_elim (¬ a ∨ ¬ b) (and_intro Ha Hb) H) (assume Hnb, or_intro_right (¬ a) Hnb)) (assume Hna, or_intro_left (¬ b) Hna)) - (assume (H : ¬ a ∨ ¬ b), not_intro (assume (N : a ∧ b), + (assume (H : ¬ a ∨ ¬ b) (N : a ∧ b), or_elim H (assume Hna, absurd (and_elim_left N) Hna) - (assume Hnb, absurd (and_elim_right N) Hnb))) + (assume Hnb, absurd (and_elim_right N) Hnb)) theorem imp_or (a b : Prop) : (a → b) = (¬ a ∨ b) := propext diff --git a/library/standard/decidable.lean b/library/standard/decidable.lean index 37c0b5d7a..56978cbeb 100644 --- a/library/standard/decidable.lean +++ b/library/standard/decidable.lean @@ -58,15 +58,14 @@ theorem decidable_iff [instance] {a b : Prop} (Ha : decidable a) (Hb : decidable := rec_on Ha (assume Ha, rec_on Hb (assume Hb : b, inl (iff_intro (assume H, Hb) (assume H, Ha))) - (assume Hnb : ¬b, inr (not_intro (assume H : a ↔ b, absurd (iff_mp_left H Ha) Hnb)))) + (assume Hnb : ¬b, inr (assume H : a ↔ b, absurd (iff_mp_left H Ha) Hnb))) (assume Hna, rec_on Hb - (assume Hb : b, inr (not_intro (assume H : a ↔ b, absurd (iff_mp_right H Hb) Hna))) + (assume Hb : b, inr (assume H : a ↔ b, absurd (iff_mp_right H Hb) Hna)) (assume Hnb : ¬b, inl (iff_intro (assume Ha, absurd_elim b Ha Hna) (assume Hb, absurd_elim a Hb Hnb)))) theorem decidable_implies [instance] {a b : Prop} (Ha : decidable a) (Hb : decidable b) : decidable (a → b) := rec_on Ha (assume Ha : a, rec_on Hb (assume Hb : b, inl (assume H, Hb)) - (assume Hnb : ¬b, inr (not_intro (assume H : a → b, - absurd (H Ha) Hnb)))) + (assume Hnb : ¬b, inr (assume H : a → b, absurd (H Ha) Hnb))) (assume Hna : ¬a, inl (assume Ha, absurd_elim b Ha Hna)) diff --git a/library/standard/logic.lean b/library/standard/logic.lean index 4bd0c37ea..0d9689148 100644 --- a/library/standard/logic.lean +++ b/library/standard/logic.lean @@ -12,7 +12,7 @@ theorem false_elim (c : Prop) (H : false) : c inductive true : Prop := | trivial : true -definition not (a : Prop) := a → false +abbreviation not (a : Prop) := a → false prefix `¬`:40 := not notation `assume` binders `,` r:(scoped f, f) := r @@ -164,7 +164,7 @@ theorem eqt_elim {a : Prop} (H : a = true) : a := (symm H) ◂ trivial theorem eqf_elim {a : Prop} (H : a = false) : ¬a -:= not_intro (assume Ha : a, H ◂ Ha) +:= assume Ha : a, H ◂ Ha theorem imp_trans {a b c : Prop} (H1 : a → b) (H2 : b → c) : a → c := assume Ha, H2 (H1 Ha) diff --git a/library/standard/nat.lean b/library/standard/nat.lean index 44bb62a0b..db9f1b349 100644 --- a/library/standard/nat.lean +++ b/library/standard/nat.lean @@ -26,8 +26,6 @@ namespace helper_tactics end using helper_tactics -theorem tst : succ (succ (succ zero)) = 3 - theorem nat_rec_zero {P : ℕ → Type} (x : P 0) (f : ∀m, P m → P (succ m)) : nat_rec x f 0 = x theorem nat_rec_succ {P : ℕ → Type} (x : P 0) (f : ∀m, P m → P (succ m)) (n : ℕ) : nat_rec x f (succ n) = f n (nat_rec x f n) @@ -41,14 +39,13 @@ definition rec_on {P : ℕ → Type} (n : ℕ) (H1 : P 0) (H2 : ∀m, P m → P -------------------------------------------------- succ pred theorem succ_ne_zero (n : ℕ) : succ n ≠ 0 -:= not_intro - (take H : succ n = 0, +:= assume H : succ n = 0, have H2 : true = false, from let f [inline] := (nat_rec false (fun a b, true)) in calc true = f (succ n) : _ ... = f 0 : {H} - ... = false : _, - absurd H2 true_ne_false) + ... = false : _, + absurd H2 true_ne_false definition pred (n : ℕ) := nat_rec 0 (fun m x, m) n @@ -80,11 +77,11 @@ theorem succ_inj {n m : ℕ} (H : succ n = succ m) : n = m ... = m : pred_succ m theorem succ_ne_self (n : ℕ) : succ n ≠ n -:= not_intro (induction_on n +:= induction_on n (take H : 1 = 0, have ne : 1 ≠ 0, from succ_ne_zero 0, absurd H ne) - (take k IH H, IH (succ_inj H))) + (take k IH H, IH (succ_inj H)) theorem decidable_eq [instance] (n m : ℕ) : decidable (n = m) := have general : ∀n, decidable (n = m), from @@ -102,7 +99,7 @@ theorem decidable_eq [instance] (n m : ℕ) : decidable (n = m) (assume Heq : n' = m', inl (congr2 succ Heq)) (assume Hne : n' ≠ m', have H1 : succ n' ≠ succ m', from - not_intro (assume Heq, absurd (succ_inj Heq) Hne), + assume Heq, absurd (succ_inj Heq) Hne, inr H1))), general n @@ -147,7 +144,7 @@ theorem add_zero_left (n : ℕ) : 0 + n = n (take m IH, show 0 + succ m = succ m, from calc 0 + succ m = succ (0 + m) : add_succ_right _ _ - ... = succ m : {IH}) + ... = succ m : {IH}) theorem add_succ_left (n m : ℕ) : (succ n) + m = succ (n + m) := induction_on m @@ -416,10 +413,9 @@ theorem le_zero {n : ℕ} (H : n ≤ 0) : n = 0 add_eq_zero_left Hk theorem not_succ_zero_le (n : ℕ) : ¬ succ n ≤ 0 -:= not_intro - (assume H : succ n ≤ 0, - have H2 : succ n = 0, from le_zero H, - absurd H2 (succ_ne_zero n)) +:= assume H : succ n ≤ 0, + have H2 : succ n = 0, from le_zero H, + absurd H2 (succ_ne_zero n) theorem le_zero_inv {n : ℕ} (H : n ≤ 0) : n = 0 := obtain (k : ℕ) (Hk : n + k = 0), from le_elim H, @@ -526,11 +522,10 @@ theorem succ_le_left_inv {n m : ℕ} (H : succ n ≤ m) : n ≤ m ∧ n ≠ m n + succ k = succ n + k : symm (add_move_succ n k) ... = m : H2, show n ≤ m, from le_intro H3) - (not_intro - (assume H3 : n = m, + (assume H3 : n = m, have H4 : succ n ≤ n, from subst (symm H3) H, have H5 : succ n = n, from le_antisym H4 (self_le_succ n), - show false, from absurd H5 (succ_ne_self n))) + show false, from absurd H5 (succ_ne_self n)) theorem le_pred_self (n : ℕ) : pred n ≤ n := case n @@ -609,11 +604,10 @@ theorem succ_le_imp_le_and_ne {n m : ℕ} (H : succ n ≤ m) : n ≤ m ∧ n ≠ := and_intro (le_trans (self_le_succ n) H) - (not_intro - (assume H2 : n = m, + (assume H2 : n = m, have H3 : succ n ≤ n, from subst (symm H2) H, have H4 : succ n = n, from le_antisym H3 (self_le_succ n), - show false, from absurd H4 (succ_ne_self n))) + show false, from absurd H4 (succ_ne_self n)) theorem pred_le_self (n : ℕ) : pred n ≤ n := @@ -693,16 +687,15 @@ theorem lt_ne {n m : ℕ} (H : n < m) : n ≠ m := and_elim_right (succ_le_left_inv H) theorem lt_irrefl (n : ℕ) : ¬ n < n -:= not_intro (assume H : n < n, absurd (refl n) (lt_ne H)) +:= assume H : n < n, absurd (refl n) (lt_ne H) theorem lt_zero (n : ℕ) : 0 < succ n := succ_le (zero_le n) theorem lt_zero_inv (n : ℕ) : ¬ n < 0 -:= not_intro - (assume H : n < 0, +:= assume H : n < 0, have H2 : succ n = 0, from le_zero_inv H, - absurd H2 (succ_ne_zero n)) + absurd H2 (succ_ne_zero n) theorem lt_positive {n m : ℕ} (H : n < m) : ∃k, m = succ k := discriminate @@ -747,10 +740,10 @@ theorem lt_trans {n m k : ℕ} (H1 : n < m) (H2 : m < k) : n < k := lt_le_trans H1 (lt_imp_le H2) theorem le_imp_not_gt {n m : ℕ} (H : n ≤ m) : ¬ n > m -:= not_intro (assume H2 : m < n, absurd (le_lt_trans H H2) (lt_irrefl n)) +:= assume H2 : m < n, absurd (le_lt_trans H H2) (lt_irrefl n) theorem lt_imp_not_ge {n m : ℕ} (H : n < m) : ¬ n ≥ m -:= not_intro (assume H2 : m ≤ n, absurd (lt_le_trans H H2) (lt_irrefl n)) +:= assume H2 : m ≤ n, absurd (lt_le_trans H H2) (lt_irrefl n) theorem lt_antisym {n m : ℕ} (H : n < m) : ¬ m < n := le_imp_not_gt (lt_imp_le H)