From 6b649aba925b6f7462da07599fe67ebb12a3460e Mon Sep 17 00:00:00 2001 From: Samuel Mimram Date: Wed, 28 Jul 2004 21:54:47 +0000 Subject: Imported Upstream version 8.0pl1 --- theories/Arith/Minus.v | 123 +++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 123 insertions(+) create mode 100755 theories/Arith/Minus.v (limited to 'theories/Arith/Minus.v') diff --git a/theories/Arith/Minus.v b/theories/Arith/Minus.v new file mode 100755 index 00000000..ba9a46ad --- /dev/null +++ b/theories/Arith/Minus.v @@ -0,0 +1,123 @@ +(************************************************************************) +(* v * The Coq Proof Assistant / The Coq Development Team *) +(* S (n - m) = S n - m. +Proof. +intros n m Le; pattern m, n in |- *; apply le_elim_rel; simpl in |- *; + auto with arith. +Qed. +Hint Resolve minus_Sn_m: arith v62. + +Theorem pred_of_minus : forall n, pred n = n - 1. +intro x; induction x; simpl in |- *; auto with arith. +Qed. + +(** Diagonal *) + +Lemma minus_n_n : forall n, 0 = n - n. +Proof. +induction n; simpl in |- *; auto with arith. +Qed. +Hint Resolve minus_n_n: arith v62. + +(** Simplification *) + +Lemma minus_plus_simpl_l_reverse : forall n m p, n - m = p + n - (p + m). +Proof. + induction p; simpl in |- *; auto with arith. +Qed. +Hint Resolve minus_plus_simpl_l_reverse: arith v62. + +(** Relation with plus *) + +Lemma plus_minus : forall n m p, n = m + p -> p = n - m. +Proof. +intros n m p; pattern m, n in |- *; apply nat_double_ind; simpl in |- *; + intros. +replace (n0 - 0) with n0; auto with arith. +absurd (0 = S (n0 + p)); auto with arith. +auto with arith. +Qed. +Hint Immediate plus_minus: arith v62. + +Lemma minus_plus : forall n m, n + m - n = m. +symmetry in |- *; auto with arith. +Qed. +Hint Resolve minus_plus: arith v62. + +Lemma le_plus_minus : forall n m, n <= m -> m = n + (m - n). +Proof. +intros n m Le; pattern n, m in |- *; apply le_elim_rel; simpl in |- *; + auto with arith. +Qed. +Hint Resolve le_plus_minus: arith v62. + +Lemma le_plus_minus_r : forall n m, n <= m -> n + (m - n) = m. +Proof. +symmetry in |- *; auto with arith. +Qed. +Hint Resolve le_plus_minus_r: arith v62. + +(** Relation with order *) + +Theorem le_minus : forall n m, n - m <= n. +Proof. +intros i h; pattern i, h in |- *; apply nat_double_ind; + [ auto + | auto + | intros m n H; simpl in |- *; apply le_trans with (m := m); auto ]. +Qed. + +Lemma lt_minus : forall n m, m <= n -> 0 < m -> n - m < n. +Proof. +intros n m Le; pattern m, n in |- *; apply le_elim_rel; simpl in |- *; + auto with arith. +intros; absurd (0 < 0); auto with arith. +intros p q lepq Hp gtp. +elim (le_lt_or_eq 0 p); auto with arith. +auto with arith. +induction 1; elim minus_n_O; auto with arith. +Qed. +Hint Resolve lt_minus: arith v62. + +Lemma lt_O_minus_lt : forall n m, 0 < n - m -> m < n. +Proof. +intros n m; pattern n, m in |- *; apply nat_double_ind; simpl in |- *; + auto with arith. +intros; absurd (0 < 0); trivial with arith. +Qed. +Hint Immediate lt_O_minus_lt: arith v62. + +Theorem not_le_minus_0 : forall n m, ~ m <= n -> n - m = 0. +intros y x; pattern y, x in |- *; apply nat_double_ind; + [ simpl in |- *; trivial with arith + | intros n H; absurd (0 <= S n); [ assumption | apply le_O_n ] + | simpl in |- *; intros n m H1 H2; apply H1; unfold not in |- *; intros H3; + apply H2; apply le_n_S; assumption ]. +Qed. \ No newline at end of file -- cgit v1.2.3