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/notation/relations/predicate_u_1.ma".
16 include "ground/relocation/pr_isi.ma".
18 (* UNIFORMITY CONDITION FOR PARTIAL RELOCATION MAPS *************************)
21 inductive pr_isu: predicate pr_map ā
23 | pr_isu_isi (f): šāØfā© ā pr_isu f
25 | pr_isu_next (f): pr_isu f ā āg. āf = g ā pr_isu g
29 "uniformity condition (partial relocation maps)"
30 'PredicateU f = (pr_isu f).
32 (* Basic inversions *********************************************************)
34 (*** isuni_inv_push *)
35 lemma pr_isu_inv_push (g): šāØgā© ā āf. ā«Æf = g ā šāØfā©.
37 [ /2 width=3 by pr_isi_inv_push/
38 | #f #_ #g #H #x #Hx destruct
39 elim (eq_inv_pr_push_next ā¦ Hx)
43 (*** isuni_inv_next *)
44 lemma pr_isu_inv_next (g): šāØgā© ā āf. āf = g ā šāØfā©.
46 [ #x #Hx elim (pr_isi_inv_next ā¦ Hf ā¦ Hx)
47 | #g #H #x #Hx destruct
48 >(eq_inv_pr_next_bi ā¦ Hx) -x //
52 (* Basic destructions *******************************************************)
54 (*** isuni_fwd_push *)
55 lemma pr_isu_fwd_push (g): šāØgā© ā āf. ā«Æf = g ā šāØfā©.
56 /3 width=3 by pr_isu_inv_push, pr_isu_isi/ qed-.