X-Git-Url: http://matita.cs.unibo.it/gitweb/?p=helm.git;a=blobdiff_plain;f=matita%2Fmatita%2Fcontribs%2Flambdadelta%2Fground%2Farith%2Fnat_succ.ma;h=742c6b25776f397bfddd57541f8a007ad5a0b4cc;hp=bb2300f021a2e549d6f25bbb13dd49ace62a07cc;hb=8fdf1af656038d0245eba64ff2531bbe94ce0e9e;hpb=77c9255de3c5f7780aeacd745703a1cc76328a68 diff --git a/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma b/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma index bb2300f02..742c6b257 100644 --- a/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma +++ b/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma @@ -16,7 +16,7 @@ include "ground/arith/nat.ma". (* SUCCESSOR FOR NON-NEGATIVE INTEGERS **************************************) -definition nsucc_pos (m): pnat ≝ +definition npsucc (m): pnat ≝ match m with [ nzero ⇒ 𝟏 | ninj p ⇒ ↑p @@ -24,7 +24,7 @@ match m with interpretation "positive successor (non-negative integers)" - 'UpArrow m = (nsucc_pos m). + 'UpArrow m = (npsucc m). definition nsucc (m): nat ≝ ninj (↑m). @@ -35,12 +35,21 @@ interpretation (* Basic constructions ******************************************************) +lemma npsucc_zero: (𝟏) = ↑𝟎. +// qed. + +lemma npsucc_inj (p): (↑p) = ↑(ninj p). +// qed. + lemma nsucc_zero: ninj (𝟏) = ↑𝟎. // qed. lemma nsucc_inj (p): ninj (↑p) = ↑(ninj p). // qed. +lemma npsucc_succ (n): psucc (npsucc n) = npsucc (nsucc n). +// qed. + (* Basic eliminations *******************************************************) (*** nat_ind *) @@ -53,7 +62,7 @@ qed-. (*** nat_elim2 *) lemma nat_ind_2_succ (Q:relation2 …): (∀n. Q (𝟎) n) → - (∀m. Q (↑m) (𝟎)) → + (∀m. Q m (𝟎) → Q (↑m) (𝟎)) → (∀m,n. Q m n → Q (↑m) (↑n)) → ∀m,n. Q m n. #Q #IH1 #IH2 #IH3 #m @(nat_ind_succ … m) -m [ // ] @@ -62,15 +71,20 @@ qed-. (* Basic inversions *********************************************************) -(*** injective_S *) -lemma eq_inv_nsucc_bi: injective … nsucc. +lemma eq_inv_npsucc_bi: injective … npsucc. * [| #p1 ] * [2,4: #p2 ] -[1,4: