diff --git a/doc/lean/tutorial.org b/doc/lean/tutorial.org index ecfa5499d..d4f505000 100644 --- a/doc/lean/tutorial.org +++ b/doc/lean/tutorial.org @@ -528,12 +528,10 @@ the Lean standard library. =not_intro H= produces a proof for =¬ a= from =H : a → false=. That is, we obtain =¬ a= if we can derive =false= from =a=. The expression -=absurd_elim Ha Hna= produces a proof for some =b= from =Ha : a= and =Hna : ¬ a=. +=absurd Ha Hna= produces a proof for some =b= from =Ha : a= and =Hna : ¬ a=. That is, we can deduce anything if we have =a= and =¬ a=. -We now use =not_intro= and =absurd_elim= to produce a proof term for -=(a → b) → ¬b → ¬a=. =absurd Ha Hna= is just a special case of -=absurd_elim= where =b= -is false. +We now use =not_intro= and =absurd= to produce a proof term for +=(a → b) → ¬b → ¬a=. #+BEGIN_SRC lean import logic @@ -545,8 +543,7 @@ is false. In the standard library, =not a= is actually just an _abbreviation_ for =a → false=. Thus, we don't really need to use =not_intro= -explicitly. Moreover, =absurd Ha Hna= is just =Hna Ha=. -We can suppress both of them in the previous example +explicitly. #+BEGIN_SRC lean import logic @@ -562,7 +559,7 @@ Now, here is the proof term for =¬a → b → (b → a) → c= import logic variables a b c : Prop check fun (Hna : ¬ a) (Hb : b) (Hba : b → a), - absurd_elim (Hba Hb) Hna + absurd (Hba Hb) Hna #+END_SRC *** Iff (if-and-only-if) diff --git a/library/data/bool.lean b/library/data/bool.lean index 7091a59c0..6dab8d81a 100644 --- a/library/data/bool.lean +++ b/library/data/bool.lean @@ -120,7 +120,7 @@ cases_on a theorem band_eq_tt_elim_left {a b : bool} (H : a && b = tt) : a = tt := or_elim (dichotomy a) (assume H0 : a = ff, - absurd_elim + absurd (calc ff = ff && b : (band_ff_left _)⁻¹ ... = a && b : {H0⁻¹} ... = tt : H) diff --git a/library/data/int/order.lean b/library/data/int/order.lean index efb406d5c..137d7f6ee 100644 --- a/library/data/int/order.lean +++ b/library/data/int/order.lean @@ -522,7 +522,7 @@ theorem mul_lt_cancel_left_nonneg {a b c : ℤ} (Hc : c ≥ 0) (H : c * a < c * or_elim (le_or_gt b a) (assume H2 : b ≤ a, have H3 : c * b ≤ c * a, from mul_le_left_nonneg Hc H2, - absurd_elim H3 (lt_imp_not_ge H)) + absurd H3 (lt_imp_not_ge H)) (assume H2 : a < b, H2) theorem mul_lt_cancel_right_nonneg {a b c : ℤ} (Hc : c ≥ 0) (H : a * c < b * c) : a < b := @@ -543,7 +543,7 @@ or_elim (le_or_gt a b) (assume H2 : a ≤ b, H2) (assume H2 : a > b, have H3 : c * a > c * b, from mul_lt_left_pos Hc H2, - absurd_elim H3 (le_imp_not_gt H)) + absurd H3 (le_imp_not_gt H)) theorem mul_le_cancel_right_pos {a b c : ℤ} (Hc : c > 0) (H : a * c ≤ b * c) : a ≤ b := mul_le_cancel_left_pos Hc (subst (mul_comm b c) (subst (mul_comm a c) H)) @@ -617,7 +617,7 @@ or_elim (em (a = 0)) ... = sign a * sign b * (to_nat (a * b)) : by simp, have H2 : (to_nat (a * b)) ≠ 0, from take H2', mul_ne_zero Ha Hb (to_nat_eq_zero H2'), - have H3 : (to_nat (a * b)) ≠ of_nat 0, from contrapos of_nat_inj H2, + have H3 : (to_nat (a * b)) ≠ of_nat 0, from mt of_nat_inj H2, mul_cancel_right H3 H)) --set_option pp::coercion true @@ -647,7 +647,7 @@ or_elim3 (trichotomy a 0) sorry sorry sorry theorem to_nat_sign_ne_zero {a : ℤ} (H : a ≠ 0) : (to_nat (sign a)) = 1 := or_elim3 (trichotomy a 0) sorry -- (by simp) - (assume H2 : a = 0, absurd_elim H2 H) + (assume H2 : a = 0, absurd H2 H) sorry -- (by simp) diff --git a/library/data/list/basic.lean b/library/data/list/basic.lean index 8b68a94c2..9a6136270 100644 --- a/library/data/list/basic.lean +++ b/library/data/list/basic.lean @@ -164,7 +164,7 @@ theorem head_cons (x : T) (x0 : T) (t : list T) : head x0 (x :: t) = x := refl _ theorem head_concat (s t : list T) (x0 : T) : s ≠ nil → (head x0 (s ++ t) = head x0 s) := list_cases_on s - (take H : nil ≠ nil, absurd_elim (refl nil) H) + (take H : nil ≠ nil, absurd (refl nil) H) (take x s, take H : cons x s ≠ nil, calc @@ -180,7 +180,7 @@ theorem tail_cons (x : T) (l : list T) : tail (cons x l) = l := refl _ theorem cons_head_tail (x0 : T) (l : list T) : l ≠ nil → (head x0 l) :: (tail l) = l := list_cases_on l - (assume H : nil ≠ nil, absurd_elim (refl _) H) + (assume H : nil ≠ nil, absurd (refl _) H) (take x l, assume H : cons x l ≠ nil, refl _) diff --git a/library/data/nat/basic.lean b/library/data/nat/basic.lean index 4a9a1ab9f..78148b66e 100644 --- a/library/data/nat/basic.lean +++ b/library/data/nat/basic.lean @@ -255,7 +255,7 @@ induction_on n (take (H : 0 + m = 0), refl 0) (take k IH, assume (H : succ k + m = 0), - absurd_elim + absurd (show succ (k + m) = 0, from calc succ (k + m) = succ k + m : symm (add_succ_left k m) @@ -402,7 +402,7 @@ discriminate ... = succ k * succ l : {Hk} ... = k * succ l + succ l : mul_succ_left _ _ ... = succ (k * succ l + l) : add_succ_right _ _), - absurd_elim (trans Heq H) (succ_ne_zero _))) + absurd (trans Heq H) (succ_ne_zero _))) ---other inversion theorems appear below diff --git a/library/data/nat/order.lean b/library/data/nat/order.lean index ebf56e0f3..c2c48e932 100644 --- a/library/data/nat/order.lean +++ b/library/data/nat/order.lean @@ -297,7 +297,7 @@ not_succ_zero_le n theorem lt_imp_eq_succ {n m : ℕ} (H : n < m) : exists k, m = succ k := discriminate - (take (Hm : m = 0), absurd_elim (subst Hm H) (not_lt_zero n)) + (take (Hm : m = 0), absurd (subst Hm H) (not_lt_zero n)) (take (l : ℕ) (Hm : m = succ l), exists_intro l Hm) -- ### interaction with le @@ -437,7 +437,7 @@ theorem strong_induction_on {P : nat → Prop} (n : ℕ) (H : ∀n, (∀m, m < n have H1 : ∀n, ∀m, m < n → P m, from take n, induction_on n - (show ∀m, m < 0 → P m, from take m H, absurd_elim H (not_lt_zero _)) + (show ∀m, m < 0 → P m, from take m H, absurd H (not_lt_zero _)) (take n', assume IH : ∀m, m < n' → P m, have H2: P n', from H n' IH, @@ -479,7 +479,7 @@ theorem succ_imp_pos {n m : ℕ} (H : n = succ m) : n > 0 := H⁻¹ ▸ (succ_pos m) theorem ne_zero_imp_pos {n : ℕ} (H : n ≠ 0) : n > 0 := -or_elim (zero_or_pos n) (take H2 : n = 0, absurd_elim H2 H) (take H2 : n > 0, H2) +or_elim (zero_or_pos n) (take H2 : n = 0, absurd H2 H) (take H2 : n > 0, H2) theorem pos_imp_ne_zero {n : ℕ} (H : n > 0) : n ≠ 0 := ne_symm (lt_imp_ne H) @@ -512,7 +512,7 @@ discriminate n * m = 0 * m : {H2} ... = 0 : mul_zero_left m, have H4 : 0 > 0, from H3 ▸ H, - absurd_elim H4 (lt_irrefl 0)) + absurd H4 (lt_irrefl 0)) (take l : nat, assume Hl : n = succ l, Hl⁻¹ ▸ (succ_pos l)) @@ -545,7 +545,7 @@ theorem mul_lt_cancel_left {n m k : ℕ} (H : k * n < k * m) : n < m := or_elim (le_or_gt m n) (assume H2 : m ≤ n, have H3 : k * m ≤ k * n, from mul_le_left H2 k, - absurd_elim H3 (lt_imp_not_ge H)) + absurd H3 (lt_imp_not_ge H)) (assume H2 : n < m, H2) theorem mul_lt_cancel_right {n m k : ℕ} (H : n * k < m * k) : n < m := @@ -587,7 +587,7 @@ or_elim (le_or_gt n 1) (assume H5 : n > 1, have H6 : n * m ≥ 2 * 1, from mul_le H5 H4, have H7 : 1 ≥ 2, from mul_one_right 2 ▸ H ▸ H6, - absurd_elim (self_lt_succ 1) (le_imp_not_gt H7)) + absurd (self_lt_succ 1) (le_imp_not_gt H7)) theorem mul_eq_one_right {n m : ℕ} (H : n * m = 1) : m = 1 := mul_eq_one_left ((mul_comm n m) ▸ H) diff --git a/library/data/nat/sub.lean b/library/data/nat/sub.lean index 71cbb0bbf..a355cccfc 100644 --- a/library/data/nat/sub.lean +++ b/library/data/nat/sub.lean @@ -196,7 +196,7 @@ sub_induction n m ... = succ (k - 0) : {symm (sub_zero_right k)}) (take k, assume H : succ k ≤ 0, - absurd_elim H (not_succ_zero_le k)) + absurd H (not_succ_zero_le k)) (take k l, assume IH : k ≤ l → succ l - k = succ (l - k), take H : succ k ≤ succ l, @@ -215,7 +215,7 @@ sub_induction n m calc 0 + (k - 0) = k - 0 : add_zero_left (k - 0) ... = k : sub_zero_right k) - (take k, assume H : succ k ≤ 0, absurd_elim H (not_succ_zero_le k)) + (take k, assume H : succ k ≤ 0, absurd H (not_succ_zero_le k)) (take k l, assume IH : k ≤ l → k + (l - k) = l, take H : succ k ≤ succ l, @@ -271,7 +271,7 @@ have l1 : k ≤ m → n + m - k = n + (m - k), from calc n + m - 0 = n + m : sub_zero_right (n + m) ... = n + (m - 0) : {symm (sub_zero_right m)}) - (take k : ℕ, assume H : succ k ≤ 0, absurd_elim H (not_succ_zero_le k)) + (take k : ℕ, assume H : succ k ≤ 0, absurd H (not_succ_zero_le k)) (take k m, assume IH : k ≤ m → n + m - k = n + (m - k), take H : succ k ≤ succ m, diff --git a/library/logic/axioms/classical.lean b/library/logic/axioms/classical.lean index ba3252205..8295503b5 100644 --- a/library/logic/axioms/classical.lean +++ b/library/logic/axioms/classical.lean @@ -32,7 +32,7 @@ case (λ x, x = false ∨ x = true) theorem not_true : (¬true) = false := have aux : (¬true) ≠ true, from assume H : (¬true) = true, - absurd_not_true (H⁻¹ ▸ trivial), + absurd trivial (H⁻¹ ▸ trivial), resolve_right (prop_complete (¬true)) aux theorem not_false : (¬false) = true := @@ -98,9 +98,9 @@ eqt_intro (hrefl a) theorem not_or (a b : Prop) : (¬(a ∨ b)) = (¬a ∧ ¬b) := propext (assume H, or_elim (em a) - (assume Ha, absurd_elim (or_inl Ha) H) + (assume Ha, absurd (or_inl Ha) H) (assume Hna, or_elim (em b) - (assume Hb, absurd_elim (or_inr Hb) H) + (assume Hb, absurd (or_inr Hb) H) (assume Hnb, and_intro Hna Hnb))) (assume (H : ¬a ∧ ¬b) (N : a ∨ b), or_elim N @@ -111,7 +111,7 @@ theorem not_and (a b : Prop) : (¬(a ∧ b)) = (¬a ∨ ¬b) := propext (assume H, or_elim (em a) (assume Ha, or_elim (em b) - (assume Hb, absurd_elim (and_intro Ha Hb) H) + (assume Hb, absurd (and_intro Ha Hb) H) (assume Hnb, or_inr Hnb)) (assume Hna, or_inl Hna)) (assume (H : ¬a ∨ ¬b) (N : a ∧ b), @@ -153,7 +153,7 @@ propext (assume H, eqf_elim H) (assume H, eqf_intro H) theorem not_exists_forall {A : Type} {P : A → Prop} (H : ¬∃x, P x) : ∀x, ¬P x := take x, or_elim (em (P x)) - (assume Hp : P x, absurd_elim (exists_intro x Hp) H) + (assume Hp : P x, absurd (exists_intro x Hp) H) (assume Hn : ¬P x, Hn) theorem not_forall_exists {A : Type} {P : A → Prop} (H : ¬∀x, P x) : ∃x, ¬P x := diff --git a/library/logic/classes/decidable.lean b/library/logic/classes/decidable.lean index 677d6ce53..9f9629b15 100644 --- a/library/logic/classes/decidable.lean +++ b/library/logic/classes/decidable.lean @@ -27,10 +27,10 @@ theorem irrelevant {p : Prop} (d1 d2 : decidable p) : d1 = d2 := decidable_rec (assume Hp1 : p, decidable_rec (assume Hp2 : p, congr_arg inl (refl Hp1)) -- using proof irrelevance for Prop - (assume Hnp2 : ¬p, absurd_elim Hp1 Hnp2) + (assume Hnp2 : ¬p, absurd Hp1 Hnp2) d2) (assume Hnp1 : ¬p, decidable_rec - (assume Hp2 : p, absurd_elim Hp2 Hnp1) + (assume Hp2 : p, absurd Hp2 Hnp1) (assume Hnp2 : ¬p, congr_arg inr (refl Hnp1)) -- using proof irrelevance for Prop d2) d1 @@ -76,7 +76,7 @@ rec_on Ha (assume Hna, rec_on Hb (assume Hb : b, inr (assume H : a ↔ b, absurd (iff_elim_right H Hb) Hna)) (assume Hnb : ¬b, inl - (iff_intro (assume Ha, absurd_elim Ha Hna) (assume Hb, absurd_elim Hb Hnb)))) + (iff_intro (assume Ha, absurd Ha Hna) (assume Hb, absurd Hb Hnb)))) theorem implies_decidable [instance] {a b : Prop} (Ha : decidable a) (Hb : decidable b) : decidable (a → b) := @@ -84,7 +84,7 @@ rec_on Ha (assume Ha : a, rec_on Hb (assume Hb : b, inl (assume H, Hb)) (assume Hnb : ¬b, inr (assume H : a → b, absurd (H Ha) Hnb))) - (assume Hna : ¬a, inl (assume Ha, absurd_elim Ha Hna)) + (assume Hna : ¬a, inl (assume Ha, absurd Ha Hna)) theorem decidable_iff_equiv {a b : Prop} (Ha : decidable a) (H : a ↔ b) : decidable b := rec_on Ha diff --git a/library/logic/connectives/basic.lean b/library/logic/connectives/basic.lean index 08db34fb7..b941ad592 100644 --- a/library/logic/connectives/basic.lean +++ b/library/logic/connectives/basic.lean @@ -59,18 +59,18 @@ theorem or_elim {a b c : Prop} (H1 : a ∨ b) (H2 : a → c) (H3 : b → c) : c or_rec H2 H3 H1 theorem resolve_right {a b : Prop} (H1 : a ∨ b) (H2 : ¬a) : b := -or_elim H1 (assume Ha, absurd_elim Ha H2) (assume Hb, Hb) +or_elim H1 (assume Ha, absurd Ha H2) (assume Hb, Hb) theorem resolve_left {a b : Prop} (H1 : a ∨ b) (H2 : ¬b) : a := -or_elim H1 (assume Ha, Ha) (assume Hb, absurd_elim Hb H2) +or_elim H1 (assume Ha, Ha) (assume Hb, absurd Hb H2) theorem or_swap {a b : Prop} (H : a ∨ b) : b ∨ a := or_elim H (assume Ha, or_inr Ha) (assume Hb, or_inl Hb) theorem or_not_intro {a b : Prop} (Hna : ¬a) (Hnb : ¬b) : ¬(a ∨ b) := assume H : a ∨ b, or_elim H - (assume Ha, absurd_elim Ha Hna) - (assume Hb, absurd_elim Hb Hnb) + (assume Ha, absurd Ha Hna) + (assume Hb, absurd Hb Hnb) theorem or_imp_or {a b c d : Prop} (H1 : a ∨ b) (H2 : a → c) (H3 : b → d) : c ∨ d := or_elim H1 diff --git a/library/logic/connectives/eq.lean b/library/logic/connectives/eq.lean index ca23f521d..4b12924fa 100644 --- a/library/logic/connectives/eq.lean +++ b/library/logic/connectives/eq.lean @@ -131,4 +131,4 @@ theorem p_ne_false {p : Prop} (Hp : p) : p ≠ false := assume Heq : p = false, Heq ▸ Hp theorem p_ne_true {p : Prop} (Hnp : ¬p) : p ≠ true := -assume Heq : p = true, absurd_not_true (Heq ▸ Hnp) +assume Heq : p = true, absurd trivial (Heq ▸ Hnp) diff --git a/library/logic/connectives/if.lean b/library/logic/connectives/if.lean index ce655ca2b..9f770dc71 100644 --- a/library/logic/connectives/if.lean +++ b/library/logic/connectives/if.lean @@ -15,12 +15,12 @@ notation `if` c `then` t `else` e:45 := ite c t e theorem if_pos {c : Prop} {H : decidable c} (Hc : c) {A : Type} (t e : A) : (if c then t else e) = t := decidable_rec (assume Hc : c, refl (@ite c (inl Hc) A t e)) - (assume Hnc : ¬c, absurd_elim Hc Hnc) + (assume Hnc : ¬c, absurd Hc Hnc) H theorem if_neg {c : Prop} {H : decidable c} (Hnc : ¬c) {A : Type} (t e : A) : (if c then t else e) = e := decidable_rec - (assume Hc : c, absurd_elim Hc Hnc) + (assume Hc : c, absurd Hc Hnc) (assume Hnc : ¬c, refl (@ite c (inr Hnc) A t e)) H @@ -41,9 +41,9 @@ theorem if_cond_congr {c₁ c₂ : Prop} {H₁ : decidable c₁} {H₂ : decidab rec_on H₁ (assume Hc₁ : c₁, rec_on H₂ (assume Hc₂ : c₂, (if_pos Hc₁ t e) ⬝ (if_pos Hc₂ t e)⁻¹) - (assume Hnc₂ : ¬c₂, absurd_elim (iff_elim_left Heq Hc₁) Hnc₂)) + (assume Hnc₂ : ¬c₂, absurd (iff_elim_left Heq Hc₁) Hnc₂)) (assume Hnc₁ : ¬c₁, rec_on H₂ - (assume Hc₂ : c₂, absurd_elim (iff_elim_right Heq Hc₂) Hnc₁) + (assume Hc₂ : c₂, absurd (iff_elim_right Heq Hc₂) Hnc₁) (assume Hnc₂ : ¬c₂, (if_neg Hnc₁ t e) ⬝ (if_neg Hnc₂ t e)⁻¹)) theorem if_congr_aux {c₁ c₂ : Prop} {H₁ : decidable c₁} {H₂ : decidable c₂} {A : Type} {t₁ t₂ e₁ e₂ : A} diff --git a/library/logic/connectives/prop.lean b/library/logic/connectives/prop.lean index d0e53ce5a..1f80d5894 100644 --- a/library/logic/connectives/prop.lean +++ b/library/logic/connectives/prop.lean @@ -35,7 +35,8 @@ theorem not_intro {a : Prop} (H : a → false) : ¬a := H theorem not_elim {a : Prop} (H1 : ¬a) (H2 : a) : false := H1 H2 -theorem absurd {a : Prop} (H1 : a) (H2 : ¬a) : false := H2 H1 +theorem absurd {a : Prop} {b : Prop} (H1 : a) (H2 : ¬a) : b := +false_elim b (H2 H1) theorem not_not_intro {a : Prop} (Ha : a) : ¬¬a := assume Hna : ¬a, absurd Ha Hna @@ -43,20 +44,11 @@ assume Hna : ¬a, absurd Ha Hna theorem mt {a b : Prop} (H1 : a → b) (H2 : ¬b) : ¬a := assume Ha : a, absurd (H1 Ha) H2 -theorem absurd_elim {a : Prop} {b : Prop} (H1 : a) (H2 : ¬a) : b := -false_elim b (absurd H1 H2) - -theorem absurd_not_true (H : ¬true) : false := -absurd trivial H - theorem not_false_trivial : ¬false := assume H : false, H theorem not_implies_left {a b : Prop} (H : ¬(a → b)) : ¬¬a := -assume Hna : ¬a, absurd (assume Ha : a, absurd_elim Ha Hna) H +assume Hna : ¬a, absurd (assume Ha : a, absurd Ha Hna) H theorem not_implies_right {a b : Prop} (H : ¬(a → b)) : ¬b := assume Hb : b, absurd (assume Ha : a, Hb) H - -theorem contrapos {a b : Prop} (Hab : a → b) : (¬b → ¬a) := -assume Hnb Ha, Hnb (Hab Ha) diff --git a/library/logic/examples/nuprl_examples.lean b/library/logic/examples/nuprl_examples.lean index e5c0f299d..0c2929f09 100644 --- a/library/logic/examples/nuprl_examples.lean +++ b/library/logic/examples/nuprl_examples.lean @@ -18,7 +18,7 @@ assume Hab Hbc Ha, -- 3. False Propositions and Negation theorem thm4 {P Q : Prop} : ¬P → P → Q := assume Hnp Hp, - absurd_elim Hp Hnp + absurd Hp Hnp theorem thm5 {P : Prop} : P → ¬¬P := assume (Hp : P) (HnP : ¬P), @@ -31,7 +31,7 @@ assume (Hpq : P → Q) (Hnq : ¬Q) (Hp : P), theorem thm7 {P Q : Prop} : (P → ¬P) → (P → Q) := assume Hpnp Hp, - absurd_elim Hp (Hpnp Hp) + absurd Hp (Hpnp Hp) theorem thm8 {P Q : Prop} : ¬(P → Q) → (P → ¬Q) := assume (Hn : ¬(P → Q)) (Hp : P) (Hq : Q), @@ -44,7 +44,7 @@ theorem thm9 {P : Prop} : (P ∨ ¬P) → (¬¬P → P) := assume (em : P ∨ ¬P) (Hnn : ¬¬P), or_elim em (assume Hp, Hp) - (assume Hn, absurd_elim Hn Hnn) + (assume Hn, absurd Hn Hnn) theorem thm10 {P : Prop} : ¬¬(P ∨ ¬P) := assume Hnem : ¬(P ∨ ¬P), @@ -76,7 +76,7 @@ assume (H : ¬P ∧ ¬Q) (Hn : P ∨ Q), theorem thm14 {P Q : Prop} : ¬P ∨ Q → P → Q := assume (Hor : ¬P ∨ Q) (Hp : P), or_elim Hor - (assume Hnp : ¬P, absurd_elim Hp Hnp) + (assume Hnp : ¬P, absurd Hp Hnp) (assume Hq : Q, Hq) theorem thm15 {P Q : Prop} : (P → Q) → ¬¬(¬P ∨ Q) := @@ -129,7 +129,7 @@ assume (Hem : C ∨ ¬C) (Hin : ∃x : T, true) (H1 : C → ∃x, P x), exists_intro w Hr) (assume Hnc : ¬C, obtain (w : T) (Hw : true), from Hin, - have Hr : C → P w, from assume Hc, absurd_elim Hc Hnc, + have Hr : C → P w, from assume Hc, absurd Hc Hnc, exists_intro w Hr) theorem thm19b : (∃x, C → P x) → C → (∃x, P x) := @@ -147,7 +147,7 @@ assume Hem Hin Hnf H, have H1 : ¬(∀x, P x), from mt H Hnc, have H2 : ∃x, ¬P x, from Hnf H1, obtain (w : T) (Hw : ¬P w), from H2, - exists_intro w (assume H : P w, absurd_elim H Hw)) + exists_intro w (assume H : P w, absurd H Hw)) theorem thm20b : (∃x, P x → C) → (∀ x, P x) → C := assume Hex Hall, diff --git a/tests/lean/run/class4.lean b/tests/lean/run/class4.lean index 2e7ecab1e..3a9110d35 100644 --- a/tests/lean/run/class4.lean +++ b/tests/lean/run/class4.lean @@ -35,12 +35,12 @@ theorem is_zero_to_eq (x : nat) (H : is_zero x) : x = zero (assume Hz : x = zero, Hz) (assume Hs : (∃ n, x = succ n), exists_elim Hs (λ (w : nat) (Hw : x = succ w), - absurd_elim H (subst (symm Hw) (not_is_zero_succ w)))) + absurd H (subst (symm Hw) (not_is_zero_succ w)))) theorem is_not_zero_to_eq {x : nat} (H : ¬ is_zero x) : ∃ n, x = succ n := or_elim (dichotomy x) (assume Hz : x = zero, - absurd_elim (subst (symm Hz) is_zero_zero) H) + absurd (subst (symm Hz) is_zero_zero) H) (assume Hs, Hs) theorem not_zero_add (x y : nat) (H : ¬ is_zero y) : ¬ is_zero (x + y) diff --git a/tests/lean/run/tactic12.lean b/tests/lean/run/tactic12.lean index 5a1128276..95c7e0b8d 100644 --- a/tests/lean/run/tactic12.lean +++ b/tests/lean/run/tactic12.lean @@ -6,6 +6,6 @@ theorem tst (a b : Prop) (H : ¬ a ∨ ¬ b) (Hb : b) : ¬ a ∧ b apply not_intro; exact (assume Ha, or_elim H - (assume Hna, absurd Ha Hna) - (assume Hnb, absurd Hb Hnb)); + (assume Hna, @absurd _ false Ha Hna) + (assume Hnb, @absurd _ false Hb Hnb)); assumption diff --git a/tests/lean/run/tactic13.lean b/tests/lean/run/tactic13.lean index 88b57d269..74f423acc 100644 --- a/tests/lean/run/tactic13.lean +++ b/tests/lean/run/tactic13.lean @@ -6,7 +6,7 @@ begin apply and_intro, apply not_intro, assume Ha, or_elim H - (assume Hna, absurd Ha Hna) - (assume Hnb, absurd Hb Hnb), + (assume Hna, @absurd _ false Ha Hna) + (assume Hnb, @absurd _ false Hb Hnb), assumption -end \ No newline at end of file +end diff --git a/tests/lean/run/tactic14.lean b/tests/lean/run/tactic14.lean index 575475cc8..23fb1c72b 100644 --- a/tests/lean/run/tactic14.lean +++ b/tests/lean/run/tactic14.lean @@ -9,6 +9,6 @@ set_begin_end_tactic basic_tac -- basic_tac is automatically applied to each ele theorem tst (a b : Prop) (H : ¬ a ∨ ¬ b) (Hb : b) : ¬ a ∧ b := begin assume Ha, or_elim H - (assume Hna, absurd Ha Hna) - (assume Hnb, absurd Hb Hnb) -end \ No newline at end of file + (assume Hna, @absurd _ false Ha Hna) + (assume Hnb, @absurd _ false Hb Hnb) +end diff --git a/tests/lean/slow/nat_wo_hints.lean b/tests/lean/slow/nat_wo_hints.lean index 2930b5549..18dcd8847 100644 --- a/tests/lean/slow/nat_wo_hints.lean +++ b/tests/lean/slow/nat_wo_hints.lean @@ -228,7 +228,7 @@ theorem add_eq_zero_left {n m : ℕ} : n + m = 0 → n = 0 (take (H : 0 + m = 0), refl 0) (take k IH, assume (H : succ k + m = 0), - absurd_elim + absurd (show succ (k + m) = 0, from calc succ (k + m) = succ k + m : symm (add_succ_left k m) @@ -376,7 +376,7 @@ theorem mul_eq_zero {n m : ℕ} (H : n * m = 0) : n = 0 ∨ m = 0 ... = succ k * succ l : { Hk } ... = k * succ l + succ l : mul_succ_left _ _ ... = succ (k * succ l + l) : add_succ_right _ _), - absurd_elim (trans Heq H) (succ_ne_zero _))) + absurd (trans Heq H) (succ_ne_zero _))) -- see more under "positivity" below -------------------------------------------------- le @@ -694,7 +694,7 @@ theorem lt_zero_inv (n : ℕ) : ¬ n < 0 theorem lt_positive {n m : ℕ} (H : n < m) : ∃k, m = succ k := discriminate - (take (Hm : m = 0), absurd_elim (subst Hm H) (lt_zero_inv n)) + (take (Hm : m = 0), absurd (subst Hm H) (lt_zero_inv n)) (take (l : ℕ) (Hm : m = succ l), exists_intro l Hm) ---------- interaction with le @@ -830,7 +830,7 @@ theorem strong_induction_on {P : ℕ → Prop} (n : ℕ) (IH : ∀n, (∀m, m < (take m : ℕ, assume H4 : m < k, have H5 : m < 0, from subst H2 H4, - absurd_elim H5 (lt_zero_inv m)), + absurd H5 (lt_zero_inv m)), show P k, from IH k H3) (take l : ℕ, assume IHl : ∀k, k ≤ l → P k, @@ -866,7 +866,7 @@ theorem add_eq_self {n m : ℕ} (H : n + m = n) : m = 0 ... = n : H, have H3 : n < n, from lt_intro H2, have H4 : n ≠ n, from lt_ne H3, - absurd_elim (refl n) H4) + absurd (refl n) H4) -------------------------------------------------- positivity @@ -881,11 +881,11 @@ theorem succ_positive {n m : ℕ} (H : n = succ m) : n > 0 := subst (symm H) (lt_zero m) theorem ne_zero_positive {n : ℕ} (H : n ≠ 0) : n > 0 -:= or_elim (zero_or_positive n) (take H2 : n = 0, absurd_elim H2 H) (take H2 : n > 0, H2) +:= or_elim (zero_or_positive n) (take H2 : n = 0, absurd H2 H) (take H2 : n > 0, H2) theorem pos_imp_eq_succ {n : ℕ} (H : n > 0) : ∃l, n = succ l := discriminate - (take H2, absurd_elim (subst H2 H) (lt_irrefl 0)) + (take H2, absurd (subst H2 H) (lt_irrefl 0)) (take l Hl, exists_intro l Hl) theorem add_positive_right (n : ℕ) {k : ℕ} (H : k > 0) : n + k > n @@ -918,7 +918,7 @@ theorem succ_imp_pos {n m : ℕ} (H : n = succ m) : n > 0 := subst (symm H) (succ_pos m) theorem ne_zero_pos {n : ℕ} (H : n ≠ 0) : n > 0 -:= or_elim (zero_or_pos n) (take H2 : n = 0, absurd_elim H2 H) (take H2 : n > 0, H2) +:= or_elim (zero_or_pos n) (take H2 : n = 0, absurd H2 H) (take H2 : n > 0, H2) theorem add_pos_right (n : ℕ) {k : ℕ} (H : k > 0) : n + k > n := subst (add_zero_right n) (add_lt_left H n) @@ -945,7 +945,7 @@ theorem mul_positive_inv_left {n m : ℕ} (H : n * m > 0) : n > 0 n * m = 0 * m : {H2} ... = 0 : mul_zero_left m, have H4 : 0 > 0, from subst H3 H, - absurd_elim H4 (lt_irrefl 0)) + absurd H4 (lt_irrefl 0)) (take l : ℕ, assume Hl : n = succ l, subst (symm Hl) (lt_zero l)) @@ -1061,7 +1061,7 @@ theorem mul_eq_one_left {n m : ℕ} (H : n * m = 1) : n = 1 (assume H5 : n > 1, have H6 : n * m ≥ 2 * 1, from mul_le H5 H4, have H7 : 1 ≥ 2, from subst (mul_one_right 2) (subst H H6), - absurd_elim (self_lt_succ 1) (le_imp_not_gt H7)) + absurd (self_lt_succ 1) (le_imp_not_gt H7)) theorem mul_eq_one_right {n m : ℕ} (H : n * m = 1) : m = 1 := mul_eq_one_left (subst (mul_comm n m) H) @@ -1222,7 +1222,7 @@ theorem succ_sub {m n : ℕ} : m ≥ n → succ m - n = succ (m - n) ... = succ (k - 0) : {symm (sub_zero_right k)}) (take k, assume H : succ k ≤ 0, - absurd_elim H (not_succ_zero_le k)) + absurd H (not_succ_zero_le k)) (take k l, assume IH : k ≤ l → succ l - k = succ (l - k), take H : succ k ≤ succ l, @@ -1241,7 +1241,7 @@ theorem add_sub_le {n m : ℕ} : n ≤ m → n + (m - n) = m calc 0 + (k - 0) = k - 0 : add_zero_left (k - 0) ... = k : sub_zero_right k) - (take k, assume H : succ k ≤ 0, absurd_elim H (not_succ_zero_le k)) + (take k, assume H : succ k ≤ 0, absurd H (not_succ_zero_le k)) (take k l, assume IH : k ≤ l → k + (l - k) = l, take H : succ k ≤ succ l, @@ -1299,7 +1299,7 @@ theorem add_sub_assoc {m k : ℕ} (H : k ≤ m) (n : ℕ) : n + m - k = n + (m - calc n + m - 0 = n + m : sub_zero_right (n + m) ... = n + (m - 0) : {symm (sub_zero_right m)}) - (take k : ℕ, assume H : succ k ≤ 0, absurd_elim H (not_succ_zero_le k)) + (take k : ℕ, assume H : succ k ≤ 0, absurd H (not_succ_zero_le k)) (take k m, assume IH : k ≤ m → n + m - k = n + (m - k), take H : succ k ≤ succ m,