1 (**************************************************************************)
4 (* ||A|| A project by Andrea Asperti *)
6 (* ||I|| Developers: *)
7 (* ||T|| The HELM team. *)
8 (* ||A|| http://helm.cs.unibo.it *)
10 (* \ / This file is distributed under the terms of the *)
11 (* v GNU General Public License Version 2 *)
13 (**************************************************************************)
15 include "ground/relocation/pr_pat_lt.ma".
16 include "ground/relocation/pr_nat.ma".
17 include "ground/relocation/pr_ist.ma".
18 include "ground/relocation/pr_after_pat.ma".
20 (* RELATIONAL COMPOSITION FOR PARTIAL RELOCATION MAPS ***********************)
22 (* Destructions with pr_ist *************************************************)
24 (*** after_istot_fwd *)
25 lemma pr_after_ist_des:
26 โf2,f1,f. f2 โ f1 โ f โ ๐โจf2โฉ โ ๐โจf1โฉ โ ๐โจfโฉ.
27 #f2 #f1 #f #Hf #Hf2 #Hf1 #i1 elim (Hf1 i1) -Hf1
28 #i2 #Hf1 elim (Hf2 i2) -Hf2
29 /3 width=7 by pr_after_des_pat, ex_intro/
32 (*** after_fwd_istot_dx *)
33 lemma pr_after_des_ist_dx:
34 โf2,f1,f. f2 โ f1 โ f โ ๐โจfโฉ โ ๐โจf1โฉ.
35 #f2 #f1 #f #H #Hf #i1 elim (Hf i1) -Hf
36 #i2 #Hf elim (pr_after_pat_des โฆ Hf โฆ H) -f /2 width=2 by ex_intro/
39 (*** after_fwd_istot_sn *)
40 lemma pr_after_des_ist_sn:
41 โf2,f1,f. f2 โ f1 โ f โ ๐โจfโฉ โ ๐โจf2โฉ.
42 #f2 #f1 #f #H #Hf #i1 elim (Hf i1) -Hf
43 #i #Hf elim (pr_after_pat_des โฆ Hf โฆ H) -f
44 #i2 #Hf1 #Hf2 lapply (pr_pat_increasing โฆ Hf1) -f1
45 #Hi12 elim (pr_pat_le_ex โฆ Hf2 โฆ Hi12) -i2 /2 width=2 by ex_intro/
49 lemma pr_after_des_ist_pat:
50 โf1,i1,i2. @โจi1, f1โฉ โ i2 โ โf2. ๐โจf2โฉ โ โf. f2 โ f1 โ f โ
51 โโi. @โจi2, f2โฉ โ i & @โจi1, fโฉ โ i.
52 #f1 #i1 #i2 #Hf1 #f2 #Hf2 #f #Hf elim (Hf2 i2) -Hf2
53 /3 width=8 by pr_after_des_pat, ex2_intro/
56 lemma pr_after_des_ist_nat:
57 โf1,l1,l2. @โโจl1, f1โฉ โ l2 โ โf2. ๐โจf2โฉ โ โf. f2 โ f1 โ f โ
58 โโl. @โโจl2, f2โฉ โ l & @โโจl1, fโฉ โ l.
59 #f1 #l1 #l2 #H1 #f2 #H2 #f #Hf
60 elim (pr_after_des_ist_pat โฆ H1 โฆ H2 โฆ Hf) -f1 -H2
61 /2 width=3 by ex2_intro/
64 (* Inversions with pr_ist ***************************************************)
66 (*** after_inv_istot *)
67 lemma pr_after_inv_ist:
68 โf2,f1,f. f2 โ f1 โ f โ ๐โจfโฉ โ โงโง ๐โจf2โฉ & ๐โจf1โฉ.
69 /3 width=4 by pr_after_des_ist_sn, pr_after_des_ist_dx, conj/ qed-.