X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=matita%2Fmatita%2Fcontribs%2Flambdadelta%2Fground%2Farith%2Fnat_succ.ma;h=742c6b25776f397bfddd57541f8a007ad5a0b4cc;hb=8fdf1af656038d0245eba64ff2531bbe94ce0e9e;hp=9455ca7447ec71159d8b204b184ebeaa8d209282;hpb=21de0d35017656c5a55528390b54b0b2ae395b44;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 9455ca744..742c6b257 100644 --- a/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma +++ b/matita/matita/contribs/lambdadelta/ground/arith/nat_succ.ma @@ -16,23 +16,40 @@ 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 npsucc (m): pnat ≝ +match m with +[ nzero ⇒ 𝟏 +| ninj p ⇒ ↑p ]. +interpretation + "positive successor (non-negative integers)" + 'UpArrow m = (npsucc m). + +definition nsucc (m): nat ≝ + ninj (↑m). + interpretation "successor (non-negative integers)" 'UpArrow m = (nsucc m). (* 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 *) @@ -43,30 +60,43 @@ lemma nat_ind_succ (Q:predicate …): qed-. (*** nat_elim2 *) -lemma nat_ind_succ_2 (Q:relation2 …): +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 [ // ] #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. +lemma eq_inv_npsucc_bi: injective … npsucc. * [| #p1 ] * [2,4: #p2 ] -[1,4: