X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=matita%2Fmatita%2Fcontribs%2Flambdadelta%2Fground%2Farith%2Fnat_succ.ma;h=bb2300f021a2e549d6f25bbb13dd49ace62a07cc;hb=4d232392091ee233afc26ecf3120dd5f5c6a33c8;hp=a1532adebd035c9ca1ff67af2105d54cc4226ee7;hpb=5e72e41f4f86814e56d4b00959ccc56c71042a4c;p=helm.git diff --git a/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma b/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma index a1532adeb..bb2300f02 100644 --- a/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma +++ b/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma @@ -16,16 +16,24 @@ include "ground/arith/nat.ma". (* SUCCESSOR FOR NON-NEGATIVE INTEGERS **************************************) -definition nsucc: nat → nat ≝ λm. match m with -[ nzero ⇒ ninj (𝟏) -| ninj p ⇒ ninj (↑p) +definition nsucc_pos (m): pnat ≝ +match m with +[ nzero ⇒ 𝟏 +| ninj p ⇒ ↑p ]. interpretation - "successor (non-negative integers" + "positive successor (non-negative integers)" + 'UpArrow m = (nsucc_pos m). + +definition nsucc (m): nat ≝ + ninj (↑m). + +interpretation + "successor (non-negative integers)" 'UpArrow m = (nsucc m). -(* Basic rewrites ***********************************************************) +(* Basic constructions ******************************************************) lemma nsucc_zero: ninj (𝟏) = ↑𝟎. // qed. @@ -36,23 +44,23 @@ lemma nsucc_inj (p): ninj (↑p) = ↑(ninj p). (* Basic eliminations *******************************************************) (*** nat_ind *) -lemma nat_ind (Q:predicate …): +lemma nat_ind_succ (Q:predicate …): Q (𝟎) → (∀n. Q n → Q (↑n)) → ∀n. Q n. #Q #IH1 #IH2 * // #p elim p -p /2 width=1 by/ qed-. (*** nat_elim2 *) -lemma nat_ind_2 (Q:relation2 …): +lemma nat_ind_2_succ (Q:relation2 …): (∀n. Q (𝟎) n) → (∀m. Q (↑m) (𝟎)) → (∀m,n. Q m n → Q (↑m) (↑n)) → ∀m,n. Q m n. -#Q #IH1 #IH2 #IH3 #m elim m -m [ // ] -#m #IH #n elim n -n /2 width=1 by/ +#Q #IH1 #IH2 #IH3 #m @(nat_ind_succ … m) -m [ // ] +#m #IH #n @(nat_ind_succ … n) -n /2 width=1 by/ qed-. -(* Basic inversions ***************************************************************) +(* Basic inversions *********************************************************) (*** injective_S *) lemma eq_inv_nsucc_bi: injective … nsucc. @@ -67,6 +75,14 @@ lemma eq_inv_nsucc_zero (m): ↑m = 𝟎 → ⊥. * [