]> matita.cs.unibo.it Git - helm.git/blobdiff - matita/matita/contribs/lambdadelta/ground_2/relocation/rtmap_isfin.ma
- more results on relocation
[helm.git] / matita / matita / contribs / lambdadelta / ground_2 / relocation / rtmap_isfin.ma
index 45c8ea854656683341e2106b4668ae3e741bcf3b..875378b987c00d56b339ed8ffeb79163b6a15165 100644 (file)
@@ -23,8 +23,36 @@ definition isfin: predicate rtmap ā‰
 interpretation "test for finite colength (rtmap)"
    'IsFinite f = (isfin f).
 
+(* Basic eliminators ********************************************************)
+
+lemma isfin_ind (R:predicate rtmap): (āˆ€f.  šˆā¦ƒfā¦„ ā†’ R f) ā†’
+                                     (āˆ€f. š…ā¦ƒfā¦„ ā†’ R f ā†’ R (ā†‘f)) ā†’
+                                     (āˆ€f. š…ā¦ƒfā¦„ ā†’ R f ā†’ R (ā«Æf)) ā†’
+                                     āˆ€f. š…ā¦ƒfā¦„ ā†’ R f.
+#R #IH1 #IH2 #IH3 #f #H elim H -H
+#n #H elim H -f -n /3 width=2 by ex_intro/
+qed-.
+
+(* Basic inversion lemmas ***************************************************)
+
+lemma isfin_inv_push: āˆ€g. š…ā¦ƒgā¦„ ā†’ āˆ€f. ā†‘f = g ā†’ š…ā¦ƒfā¦„.
+#g * /3 width=4 by fcla_inv_px, ex_intro/
+qed-.
+
+lemma isfin_inv_next: āˆ€g. š…ā¦ƒgā¦„ ā†’ āˆ€f. ā«Æf = g ā†’ š…ā¦ƒfā¦„.
+#g * #n #H #f #H0 elim (fcla_inv_nx ā€¦ H ā€¦ H0) -g
+/2 width=2 by ex_intro/
+qed-.
+
 (* Basic properties *********************************************************)
 
+lemma isfin_eq_repl_back: eq_repl_back ā€¦ isfin.
+#f1 * /3 width=4 by fcla_eq_repl_back, ex_intro/
+qed-.
+
+lemma isfin_eq_repl_fwd: eq_repl_fwd ā€¦ isfin.
+/3 width=3 by isfin_eq_repl_back, eq_repl_sym/ qed-.
+
 lemma isfin_isid: āˆ€f. šˆā¦ƒfā¦„ ā†’ š…ā¦ƒfā¦„.
 /3 width=2 by fcla_isid, ex_intro/ qed.
 
@@ -36,32 +64,33 @@ lemma isfin_next: āˆ€f. š…ā¦ƒfā¦„ ā†’ š…ā¦ƒā«Æfā¦„.
 #f * /3 width=2 by fcla_next, ex_intro/
 qed.
 
-lemma isfin_eq_repl_back: eq_repl_back ā€¦ isfin.
-#f1 * /3 width=4 by fcla_eq_repl_back, ex_intro/
-qed-.
+(* Properties with iterated push ********************************************)
 
-lemma isfin_eq_repl_fwd: eq_repl_fwd ā€¦ isfin.
-/3 width=3 by isfin_eq_repl_back, eq_repl_sym/ qed-.
+lemma isfin_pushs: āˆ€n,f. š…ā¦ƒfā¦„ ā†’ š…ā¦ƒā†‘*[n]fā¦„.
+#n elim n -n /3 width=3 by isfin_push/
+qed.
 
-(* Basic eliminators ********************************************************)
+(* Inversion lemmas with iterated push **************************************)
 
-lemma isfin_ind (R:predicate rtmap): (āˆ€f.  šˆā¦ƒfā¦„ ā†’ R f) ā†’
-                                     (āˆ€f. š…ā¦ƒfā¦„ ā†’ R f ā†’ R (ā†‘f)) ā†’
-                                     (āˆ€f. š…ā¦ƒfā¦„ ā†’ R f ā†’ R (ā«Æf)) ā†’
-                                     āˆ€f. š…ā¦ƒfā¦„ ā†’ R f.
-#R #IH1 #IH2 #IH3 #f #H elim H -H
-#n #H elim H -f -n /3 width=2 by ex_intro/
-qed-.
+lemma isfin_inv_pushs: āˆ€n,g. š…ā¦ƒā†‘*[n]gā¦„ ā†’ š…ā¦ƒgā¦„.
+#n elim n -n /3 width=3 by isfin_inv_push/
+qed.
 
-(* Basic inversion lemmas ***************************************************)
+(* Properties with tail *****************************************************)
 
-lemma isfin_inv_next: āˆ€g. š…ā¦ƒgā¦„ ā†’ āˆ€f. ā«Æf = g ā†’ š…ā¦ƒfā¦„.
-#g * #n #H #f #H0 elim (fcla_inv_nx ā€¦ H ā€¦ H0) -g
-/2 width=2 by ex_intro/
+lemma isfin_tl: āˆ€f. š…ā¦ƒfā¦„ ā†’ š…ā¦ƒā«±fā¦„.
+#f elim (pn_split f) * #g #H #Hf destruct
+/3 width=3 by isfin_inv_push, isfin_inv_next/
+qed.
+
+(* Inversion lemmas with tail ***********************************************)
+
+lemma isfin_inv_tl: āˆ€f. š…ā¦ƒā«±fā¦„ ā†’ š…ā¦ƒfā¦„.
+#f elim (pn_split f) * /2 width=1 by isfin_next, isfin_push/
 qed-.
 
-(* Basic forward lemmas *****************************************************)
+(* Inversion lemmas with iterated tail **************************************)
 
-lemma isfin_fwd_push: āˆ€g. š…ā¦ƒgā¦„ ā†’ āˆ€f. ā†‘f = g ā†’ š…ā¦ƒfā¦„.
-#g * /3 width=4 by fcla_inv_px, ex_intro/
+lemma isfin_inv_tls: āˆ€n,f. š…ā¦ƒā«±*[n]fā¦„ ā†’ š…ā¦ƒfā¦„.
+#n elim n -n /3 width=1 by isfin_inv_tl/
 qed-.