2014-11-30 20:34:12 -08:00
|
|
|
|
/-
|
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
Authors: Floris van Doorn, Leonardo de Moura
|
|
|
|
|
-/
|
|
|
|
|
prelude
|
2015-03-03 16:37:38 -05:00
|
|
|
|
import init.wf init.tactic init.num
|
2015-06-04 19:16:28 -04:00
|
|
|
|
open eq.ops decidable or
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-08-27 13:46:00 -04:00
|
|
|
|
notation `ℕ` := nat
|
|
|
|
|
|
2014-11-22 00:15:51 -08:00
|
|
|
|
namespace nat
|
2015-10-13 13:16:19 -07:00
|
|
|
|
protected definition rec_on [reducible] [recursor] [unfold 2]
|
|
|
|
|
{C : ℕ → Type} (n : ℕ) (H₁ : C 0) (H₂ : Π (a : ℕ), C a → C (succ a)) : C n :=
|
|
|
|
|
nat.rec H₁ H₂ n
|
|
|
|
|
|
|
|
|
|
protected definition induction_on [recursor]
|
|
|
|
|
{C : ℕ → Prop} (n : ℕ) (H₁ : C 0) (H₂ : Π (a : ℕ), C a → C (succ a)) : C n :=
|
|
|
|
|
nat.rec H₁ H₂ n
|
|
|
|
|
|
|
|
|
|
protected definition cases_on [reducible] [recursor] [unfold 2]
|
|
|
|
|
{C : ℕ → Type} (n : ℕ) (H₁ : C 0) (H₂ : Π (a : ℕ), C (succ a)) : C n :=
|
|
|
|
|
nat.rec H₁ (λ a ih, H₂ a) n
|
|
|
|
|
|
|
|
|
|
protected definition no_confusion_type [reducible] (P : Type) (v₁ v₂ : ℕ) : Type :=
|
|
|
|
|
nat.rec
|
|
|
|
|
(nat.rec
|
|
|
|
|
(P → P)
|
|
|
|
|
(λ a₂ ih, P)
|
|
|
|
|
v₂)
|
|
|
|
|
(λ a₁ ih, nat.rec
|
|
|
|
|
P
|
|
|
|
|
(λ a₂ ih, (a₁ = a₂ → P) → P)
|
|
|
|
|
v₂)
|
|
|
|
|
v₁
|
|
|
|
|
|
|
|
|
|
protected definition no_confusion [reducible] [unfold 4]
|
|
|
|
|
{P : Type} {v₁ v₂ : ℕ} (H : v₁ = v₂) : nat.no_confusion_type P v₁ v₂ :=
|
|
|
|
|
eq.rec (λ H₁ : v₁ = v₁, nat.rec (λ h, h) (λ a ih h, h (eq.refl a)) v₁) H H
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-06-04 19:16:28 -04:00
|
|
|
|
/- basic definitions on natural numbers -/
|
|
|
|
|
inductive le (a : ℕ) : ℕ → Prop :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
| nat_refl : le a a -- use nat_refl to avoid overloading le.refl
|
2015-06-04 19:16:28 -04:00
|
|
|
|
| step : Π {b}, le a b → le a (succ b)
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-10-07 16:44:47 -07:00
|
|
|
|
definition nat_has_le [instance] [reducible] [priority nat.prio]: has_le nat := has_le.mk nat.le
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected lemma le_refl [refl] : ∀ a : nat, a ≤ a :=
|
|
|
|
|
le.nat_refl
|
2015-10-07 16:44:47 -07:00
|
|
|
|
|
|
|
|
|
protected definition lt [reducible] (n m : ℕ) := succ n ≤ m
|
|
|
|
|
definition nat_has_lt [instance] [reducible] [priority nat.prio] : has_lt nat := has_lt.mk nat.lt
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-07-07 16:37:06 -07:00
|
|
|
|
definition pred [unfold 1] (a : nat) : nat :=
|
2015-02-11 12:49:27 -08:00
|
|
|
|
nat.cases_on a zero (λ a₁, a₁)
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-06-04 19:16:28 -04:00
|
|
|
|
-- add is defined in init.num
|
|
|
|
|
|
2015-10-07 16:44:47 -07:00
|
|
|
|
protected definition sub (a b : nat) : nat :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
nat.rec_on b a (λ b₁, pred)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-07 16:44:47 -07:00
|
|
|
|
protected definition mul (a b : nat) : nat :=
|
2015-06-04 19:16:28 -04:00
|
|
|
|
nat.rec_on b zero (λ b₁ r, r + a)
|
|
|
|
|
|
2015-10-07 16:44:47 -07:00
|
|
|
|
definition nat_has_sub [instance] [reducible] [priority nat.prio] : has_sub nat :=
|
|
|
|
|
has_sub.mk nat.sub
|
|
|
|
|
|
|
|
|
|
definition nat_has_mul [instance] [reducible] [priority nat.prio] : has_mul nat :=
|
|
|
|
|
has_mul.mk nat.mul
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
/- properties of ℕ -/
|
|
|
|
|
|
2014-11-22 00:15:51 -08:00
|
|
|
|
protected definition is_inhabited [instance] : inhabited nat :=
|
|
|
|
|
inhabited.mk zero
|
|
|
|
|
|
2015-10-08 18:35:37 -07:00
|
|
|
|
protected definition has_decidable_eq [instance] [priority nat.prio] : ∀ x y : nat, decidable (x = y)
|
2015-02-25 16:20:44 -08:00
|
|
|
|
| has_decidable_eq zero zero := inl rfl
|
2015-04-30 21:26:52 -07:00
|
|
|
|
| has_decidable_eq (succ x) zero := inr (by contradiction)
|
|
|
|
|
| has_decidable_eq zero (succ y) := inr (by contradiction)
|
2015-02-25 16:20:44 -08:00
|
|
|
|
| has_decidable_eq (succ x) (succ y) :=
|
2015-05-01 18:18:29 -07:00
|
|
|
|
match has_decidable_eq x y with
|
|
|
|
|
| inl xeqy := inl (by rewrite xeqy)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
| inr xney := inr (λ h : succ x = succ y, by injection h with xeqy; exact absurd xeqy xney)
|
2015-05-01 18:18:29 -07:00
|
|
|
|
end
|
2014-11-22 00:15:51 -08:00
|
|
|
|
|
2015-06-04 19:16:28 -04:00
|
|
|
|
/- properties of inequality -/
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem le_of_eq {n m : ℕ} (p : n = m) : n ≤ m := p ▸ !nat.le_refl
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
theorem le_succ (n : ℕ) : n ≤ succ n := le.step !nat.le_refl
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem pred_le (n : ℕ) : pred n ≤ n := by cases n;repeat constructor
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem le_succ_iff_true [simp] (n : ℕ) : n ≤ succ n ↔ true :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_true_intro (le_succ n)
|
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem pred_le_iff_true [simp] (n : ℕ) : pred n ≤ n ↔ true :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_true_intro (pred_le n)
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem le_trans {n m k : ℕ} (H1 : n ≤ m) : m ≤ k → n ≤ k :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
le.rec H1 (λp H2, le.step)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
theorem le_succ_of_le {n m : ℕ} (H : n ≤ m) : n ≤ succ m := nat.le_trans H !le_succ
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
theorem le_of_succ_le {n m : ℕ} (H : succ n ≤ m) : n ≤ m := nat.le_trans !le_succ H
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem le_of_lt {n m : ℕ} (H : n < m) : n ≤ m := le_of_succ_le H
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem succ_le_succ {n m : ℕ} : n ≤ m → succ n ≤ succ m :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
le.rec !nat.le_refl (λa b, le.step)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem pred_le_pred {n m : ℕ} : n ≤ m → pred n ≤ pred m :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
le.rec !nat.le_refl (nat.rec (λa b, b) (λa b c, le.step))
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem le_of_succ_le_succ {n m : ℕ} : succ n ≤ succ m → n ≤ m :=
|
|
|
|
|
pred_le_pred
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem le_succ_of_pred_le {n m : ℕ} : pred n ≤ m → n ≤ succ m :=
|
|
|
|
|
nat.cases_on n le.step (λa, succ_le_succ)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem not_succ_le_zero (n : ℕ) : ¬succ n ≤ 0 :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
by intro H; cases H
|
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem succ_le_zero_iff_false (n : ℕ) : succ n ≤ 0 ↔ false :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
iff_false_intro !not_succ_le_zero
|
|
|
|
|
|
|
|
|
|
theorem not_succ_le_self : Π {n : ℕ}, ¬succ n ≤ n :=
|
|
|
|
|
nat.rec !not_succ_le_zero (λa b c, b (le_of_succ_le_succ c))
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem succ_le_self_iff_false [simp] (n : ℕ) : succ n ≤ n ↔ false :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_false_intro not_succ_le_self
|
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem zero_le : ∀ (n : ℕ), 0 ≤ n :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
nat.rec !nat.le_refl (λa, le.step)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem zero_le_iff_true [simp] (n : ℕ) : 0 ≤ n ↔ true :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
iff_true_intro !zero_le
|
2015-07-13 16:39:53 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem lt.step {n m : ℕ} : n < m → n < succ m := le.step
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
theorem zero_lt_succ (n : ℕ) : 0 < succ n :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
succ_le_succ !zero_le
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem zero_lt_succ_iff_true [simp] (n : ℕ) : 0 < succ n ↔ true :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_true_intro (zero_lt_succ n)
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem lt_trans {n m k : ℕ} (H1 : n < m) : m < k → n < k :=
|
|
|
|
|
nat.le_trans (le.step H1)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem lt_of_le_of_lt {n m k : ℕ} (H1 : n ≤ m) : m < k → n < k :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
nat.le_trans (succ_le_succ H1)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem lt_of_lt_of_le {n m k : ℕ} : n < m → m ≤ k → n < k := nat.le_trans
|
2015-07-13 16:39:53 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem lt_irrefl (n : ℕ) : ¬n < n := not_succ_le_self
|
2015-07-13 16:39:53 -04:00
|
|
|
|
|
2015-11-16 11:01:53 -08:00
|
|
|
|
theorem lt_self_iff_false (n : ℕ) : n < n ↔ false :=
|
|
|
|
|
iff_false_intro (λ H, absurd H (nat.lt_irrefl n))
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
theorem self_lt_succ (n : ℕ) : n < succ n := !nat.le_refl
|
2015-07-13 16:39:53 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem self_lt_succ_iff_true [simp] (n : ℕ) : n < succ n ↔ true :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_true_intro (self_lt_succ n)
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
theorem lt.base (n : ℕ) : n < succ n := !nat.le_refl
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
theorem le_lt_antisymm {n m : ℕ} (H1 : n ≤ m) (H2 : m < n) : false :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
!nat.lt_irrefl (nat.lt_of_le_of_lt H1 H2)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem le_antisymm {n m : ℕ} (H1 : n ≤ m) : m ≤ n → n = m :=
|
|
|
|
|
le.cases_on H1 (λa, rfl) (λa b c, absurd (nat.lt_of_le_of_lt b c) !nat.lt_irrefl)
|
2015-07-24 11:56:18 -04:00
|
|
|
|
|
2015-06-04 19:16:28 -04:00
|
|
|
|
theorem lt_le_antisymm {n m : ℕ} (H1 : n < m) (H2 : m ≤ n) : false :=
|
|
|
|
|
le_lt_antisymm H2 H1
|
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem nat.lt_asymm {n m : ℕ} (H1 : n < m) : ¬ m < n :=
|
2015-10-22 16:09:26 -04:00
|
|
|
|
le_lt_antisymm (nat.le_of_lt H1)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem not_lt_zero (a : ℕ) : ¬ a < 0 := !not_succ_le_zero
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem lt_zero_iff_false [simp] (a : ℕ) : a < 0 ↔ false :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_false_intro (not_lt_zero a)
|
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem eq_or_lt_of_le {a b : ℕ} (H : a ≤ b) : a = b ∨ a < b :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
le.cases_on H (inl rfl) (λn h, inr (succ_le_succ h))
|
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem le_of_eq_or_lt {a b : ℕ} (H : a = b ∨ a < b) : a ≤ b :=
|
|
|
|
|
or.elim H !nat.le_of_eq !nat.le_of_lt
|
2015-07-24 11:56:18 -04:00
|
|
|
|
|
2014-11-22 00:15:51 -08:00
|
|
|
|
-- less-than is well-founded
|
2015-06-04 19:16:28 -04:00
|
|
|
|
definition lt.wf [instance] : well_founded lt :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
well_founded.intro (nat.rec
|
|
|
|
|
(!acc.intro (λn H, absurd H (not_lt_zero n)))
|
|
|
|
|
(λn IH, !acc.intro (λm H,
|
2015-10-22 16:09:26 -04:00
|
|
|
|
elim (nat.eq_or_lt_of_le (le_of_succ_le_succ H))
|
2015-07-24 11:56:18 -04:00
|
|
|
|
(λe, eq.substr e IH) (acc.inv IH))))
|
|
|
|
|
|
|
|
|
|
definition measure {A : Type} : (A → ℕ) → A → A → Prop :=
|
|
|
|
|
inv_image lt
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
definition measure.wf {A : Type} (f : A → ℕ) : well_founded (measure f) :=
|
|
|
|
|
inv_image.wf f lt.wf
|
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem succ_lt_succ {a b : ℕ} : a < b → succ a < succ b :=
|
|
|
|
|
succ_le_succ
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem lt_of_succ_lt {a b : ℕ} : succ a < b → a < b :=
|
|
|
|
|
le_of_succ_le
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem lt_of_succ_lt_succ {a b : ℕ} : succ a < succ b → a < b :=
|
|
|
|
|
le_of_succ_le_succ
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-08 18:35:37 -07:00
|
|
|
|
definition decidable_le [instance] [priority nat.prio] : ∀ a b : nat, decidable (a ≤ b) :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
nat.rec (λm, (decidable.inl !zero_le))
|
|
|
|
|
(λn IH m, !nat.cases_on (decidable.inr (not_succ_le_zero n))
|
|
|
|
|
(λm, decidable.rec (λH, inl (succ_le_succ H))
|
|
|
|
|
(λH, inr (λa, H (le_of_succ_le_succ a))) (IH m)))
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-08 18:35:37 -07:00
|
|
|
|
definition decidable_lt [instance] [priority nat.prio] : ∀ a b : nat, decidable (a < b) :=
|
2015-10-07 16:44:47 -07:00
|
|
|
|
λ a b, decidable_le (succ a) b
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem lt_or_ge (a b : ℕ) : a < b ∨ a ≥ b :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
nat.rec (inr !zero_le) (λn, or.rec
|
|
|
|
|
(λh, inl (le_succ_of_le h))
|
2015-10-22 17:35:27 -04:00
|
|
|
|
(λh, elim (nat.eq_or_lt_of_le h) (λe, inl (eq.subst e !nat.le_refl)) inr)) b
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected definition lt_ge_by_cases {a b : ℕ} {P : Type} (H1 : a < b → P) (H2 : a ≥ b → P) : P :=
|
|
|
|
|
by_cases H1 (λh, H2 (elim !nat.lt_or_ge (λa, absurd a h) (λa, a)))
|
2015-07-24 11:56:18 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected definition lt_by_cases {a b : ℕ} {P : Type} (H1 : a < b → P) (H2 : a = b → P)
|
2015-10-22 16:09:26 -04:00
|
|
|
|
(H3 : b < a → P) : P :=
|
|
|
|
|
nat.lt_ge_by_cases H1 (λh₁,
|
2015-10-22 17:35:27 -04:00
|
|
|
|
nat.lt_ge_by_cases H3 (λh₂, H2 (nat.le_antisymm h₂ h₁)))
|
2015-07-24 11:56:18 -04:00
|
|
|
|
|
2015-10-22 17:35:27 -04:00
|
|
|
|
protected theorem lt_trichotomy (a b : ℕ) : a < b ∨ a = b ∨ b < a :=
|
|
|
|
|
nat.lt_by_cases (λH, inl H) (λH, inr (inl H)) (λH, inr (inr H))
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-22 16:09:26 -04:00
|
|
|
|
protected theorem eq_or_lt_of_not_lt {a b : ℕ} (hnlt : ¬ a < b) : a = b ∨ b < a :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
or.rec_on (nat.lt_trichotomy a b)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
(λ hlt, absurd hlt hnlt)
|
|
|
|
|
(λ h, h)
|
|
|
|
|
|
2015-07-24 11:56:18 -04:00
|
|
|
|
theorem lt_succ_of_le {a b : ℕ} : a ≤ b → a < succ b :=
|
|
|
|
|
succ_le_succ
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
theorem lt_of_succ_le {a b : ℕ} (h : succ a ≤ b) : a < b := h
|
|
|
|
|
|
|
|
|
|
theorem succ_le_of_lt {a b : ℕ} (h : a < b) : succ a ≤ b := h
|
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem succ_sub_succ_eq_sub [simp] (a b : ℕ) : succ a - succ b = a - b :=
|
2015-10-07 16:44:47 -07:00
|
|
|
|
nat.rec (by esimp) (λ b, congr_arg pred) b
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
theorem sub_eq_succ_sub_succ (a b : ℕ) : a - b = succ a - succ b :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
eq.symm !succ_sub_succ_eq_sub
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem zero_sub_eq_zero [simp] (a : ℕ) : 0 - a = 0 :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
nat.rec rfl (λ a, congr_arg pred) a
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem zero_eq_zero_sub (a : ℕ) : 0 = 0 - a :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
eq.symm !zero_sub_eq_zero
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
|
|
|
|
theorem sub_le (a b : ℕ) : a - b ≤ a :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
nat.rec_on b !nat.le_refl (λ b₁, nat.le_trans !pred_le)
|
2015-06-04 19:16:28 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem sub_le_iff_true [simp] (a b : ℕ) : a - b ≤ a ↔ true :=
|
2015-07-13 16:39:53 -04:00
|
|
|
|
iff_true_intro (sub_le a b)
|
|
|
|
|
|
2015-10-11 20:29:31 -07:00
|
|
|
|
theorem sub_lt {a b : ℕ} (H1 : 0 < a) (H2 : 0 < b) : a - b < a :=
|
2015-10-22 17:35:27 -04:00
|
|
|
|
!nat.cases_on (λh, absurd h !nat.lt_irrefl)
|
|
|
|
|
(λa h, succ_le_succ (!nat.cases_on (λh, absurd h !nat.lt_irrefl)
|
2015-07-24 11:56:18 -04:00
|
|
|
|
(λb c, eq.substr !succ_sub_succ_eq_sub !sub_le) H2)) H1
|
|
|
|
|
|
2015-07-13 16:39:53 -04:00
|
|
|
|
theorem sub_lt_succ (a b : ℕ) : a - b < succ a :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
lt_succ_of_le !sub_le
|
2015-07-13 16:39:53 -04:00
|
|
|
|
|
2015-07-22 09:01:42 -07:00
|
|
|
|
theorem sub_lt_succ_iff_true [simp] (a b : ℕ) : a - b < succ a ↔ true :=
|
2015-07-24 11:56:18 -04:00
|
|
|
|
iff_true_intro !sub_lt_succ
|
2014-11-22 00:15:51 -08:00
|
|
|
|
end nat
|