]> matita.cs.unibo.it Git - helm.git/blob - matita/matita/contribs/lambdadelta/basic_1/aprem/fwd.ma
refactoring of \lambda\delta version 1 in matita
[helm.git] / matita / matita / contribs / lambdadelta / basic_1 / aprem / fwd.ma
1 (**************************************************************************)
2 (*       ___                                                              *)
3 (*      ||M||                                                             *)
4 (*      ||A||       A project by Andrea Asperti                           *)
5 (*      ||T||                                                             *)
6 (*      ||I||       Developers:                                           *)
7 (*      ||T||         The HELM team.                                      *)
8 (*      ||A||         http://helm.cs.unibo.it                             *)
9 (*      \   /                                                             *)
10 (*       \ /        This file is distributed under the terms of the       *)
11 (*        v         GNU General Public License Version 2                  *)
12 (*                                                                        *)
13 (**************************************************************************)
14
15 (* This file was automatically generated: do not edit *********************)
16
17 include "Basic-1/aprem/defs.ma".
18
19 theorem aprem_gen_sort:
20  \forall (x: A).(\forall (i: nat).(\forall (h: nat).(\forall (n: nat).((aprem 
21 i (ASort h n) x) \to False))))
22 \def
23  \lambda (x: A).(\lambda (i: nat).(\lambda (h: nat).(\lambda (n: 
24 nat).(\lambda (H: (aprem i (ASort h n) x)).(insert_eq A (ASort h n) (\lambda 
25 (a: A).(aprem i a x)) (\lambda (_: A).False) (\lambda (y: A).(\lambda (H0: 
26 (aprem i y x)).(aprem_ind (\lambda (_: nat).(\lambda (a: A).(\lambda (_: 
27 A).((eq A a (ASort h n)) \to False)))) (\lambda (a1: A).(\lambda (a2: 
28 A).(\lambda (H1: (eq A (AHead a1 a2) (ASort h n))).(let H2 \def (eq_ind A 
29 (AHead a1 a2) (\lambda (ee: A).(match ee in A return (\lambda (_: A).Prop) 
30 with [(ASort _ _) \Rightarrow False | (AHead _ _) \Rightarrow True])) I 
31 (ASort h n) H1) in (False_ind False H2))))) (\lambda (a2: A).(\lambda (a: 
32 A).(\lambda (i0: nat).(\lambda (_: (aprem i0 a2 a)).(\lambda (_: (((eq A a2 
33 (ASort h n)) \to False))).(\lambda (a1: A).(\lambda (H3: (eq A (AHead a1 a2) 
34 (ASort h n))).(let H4 \def (eq_ind A (AHead a1 a2) (\lambda (ee: A).(match ee 
35 in A return (\lambda (_: A).Prop) with [(ASort _ _) \Rightarrow False | 
36 (AHead _ _) \Rightarrow True])) I (ASort h n) H3) in (False_ind False 
37 H4))))))))) i y x H0))) H))))).
38 (* COMMENTS
39 Initial nodes: 227
40 END *)
41
42 theorem aprem_gen_head_O:
43  \forall (a1: A).(\forall (a2: A).(\forall (x: A).((aprem O (AHead a1 a2) x) 
44 \to (eq A x a1))))
45 \def
46  \lambda (a1: A).(\lambda (a2: A).(\lambda (x: A).(\lambda (H: (aprem O 
47 (AHead a1 a2) x)).(insert_eq A (AHead a1 a2) (\lambda (a: A).(aprem O a x)) 
48 (\lambda (_: A).(eq A x a1)) (\lambda (y: A).(\lambda (H0: (aprem O y 
49 x)).(insert_eq nat O (\lambda (n: nat).(aprem n y x)) (\lambda (_: nat).((eq 
50 A y (AHead a1 a2)) \to (eq A x a1))) (\lambda (y0: nat).(\lambda (H1: (aprem 
51 y0 y x)).(aprem_ind (\lambda (n: nat).(\lambda (a: A).(\lambda (a0: A).((eq 
52 nat n O) \to ((eq A a (AHead a1 a2)) \to (eq A a0 a1)))))) (\lambda (a0: 
53 A).(\lambda (a3: A).(\lambda (_: (eq nat O O)).(\lambda (H3: (eq A (AHead a0 
54 a3) (AHead a1 a2))).(let H4 \def (f_equal A A (\lambda (e: A).(match e in A 
55 return (\lambda (_: A).A) with [(ASort _ _) \Rightarrow a0 | (AHead a _) 
56 \Rightarrow a])) (AHead a0 a3) (AHead a1 a2) H3) in ((let H5 \def (f_equal A 
57 A (\lambda (e: A).(match e in A return (\lambda (_: A).A) with [(ASort _ _) 
58 \Rightarrow a3 | (AHead _ a) \Rightarrow a])) (AHead a0 a3) (AHead a1 a2) H3) 
59 in (\lambda (H6: (eq A a0 a1)).H6)) H4)))))) (\lambda (a0: A).(\lambda (a: 
60 A).(\lambda (i: nat).(\lambda (H2: (aprem i a0 a)).(\lambda (H3: (((eq nat i 
61 O) \to ((eq A a0 (AHead a1 a2)) \to (eq A a a1))))).(\lambda (a3: A).(\lambda 
62 (H4: (eq nat (S i) O)).(\lambda (H5: (eq A (AHead a3 a0) (AHead a1 a2))).(let 
63 H6 \def (f_equal A A (\lambda (e: A).(match e in A return (\lambda (_: A).A) 
64 with [(ASort _ _) \Rightarrow a3 | (AHead a4 _) \Rightarrow a4])) (AHead a3 
65 a0) (AHead a1 a2) H5) in ((let H7 \def (f_equal A A (\lambda (e: A).(match e 
66 in A return (\lambda (_: A).A) with [(ASort _ _) \Rightarrow a0 | (AHead _ 
67 a4) \Rightarrow a4])) (AHead a3 a0) (AHead a1 a2) H5) in (\lambda (_: (eq A 
68 a3 a1)).(let H9 \def (eq_ind A a0 (\lambda (a4: A).((eq nat i O) \to ((eq A 
69 a4 (AHead a1 a2)) \to (eq A a a1)))) H3 a2 H7) in (let H10 \def (eq_ind A a0 
70 (\lambda (a4: A).(aprem i a4 a)) H2 a2 H7) in (let H11 \def (eq_ind nat (S i) 
71 (\lambda (ee: nat).(match ee in nat return (\lambda (_: nat).Prop) with [O 
72 \Rightarrow False | (S _) \Rightarrow True])) I O H4) in (False_ind (eq A a 
73 a1) H11)))))) H6)))))))))) y0 y x H1))) H0))) H)))).
74 (* COMMENTS
75 Initial nodes: 500
76 END *)
77
78 theorem aprem_gen_head_S:
79  \forall (a1: A).(\forall (a2: A).(\forall (x: A).(\forall (i: nat).((aprem 
80 (S i) (AHead a1 a2) x) \to (aprem i a2 x)))))
81 \def
82  \lambda (a1: A).(\lambda (a2: A).(\lambda (x: A).(\lambda (i: nat).(\lambda 
83 (H: (aprem (S i) (AHead a1 a2) x)).(insert_eq A (AHead a1 a2) (\lambda (a: 
84 A).(aprem (S i) a x)) (\lambda (_: A).(aprem i a2 x)) (\lambda (y: 
85 A).(\lambda (H0: (aprem (S i) y x)).(insert_eq nat (S i) (\lambda (n: 
86 nat).(aprem n y x)) (\lambda (_: nat).((eq A y (AHead a1 a2)) \to (aprem i a2 
87 x))) (\lambda (y0: nat).(\lambda (H1: (aprem y0 y x)).(aprem_ind (\lambda (n: 
88 nat).(\lambda (a: A).(\lambda (a0: A).((eq nat n (S i)) \to ((eq A a (AHead 
89 a1 a2)) \to (aprem i a2 a0)))))) (\lambda (a0: A).(\lambda (a3: A).(\lambda 
90 (H2: (eq nat O (S i))).(\lambda (H3: (eq A (AHead a0 a3) (AHead a1 a2))).(let 
91 H4 \def (f_equal A A (\lambda (e: A).(match e in A return (\lambda (_: A).A) 
92 with [(ASort _ _) \Rightarrow a0 | (AHead a _) \Rightarrow a])) (AHead a0 a3) 
93 (AHead a1 a2) H3) in ((let H5 \def (f_equal A A (\lambda (e: A).(match e in A 
94 return (\lambda (_: A).A) with [(ASort _ _) \Rightarrow a3 | (AHead _ a) 
95 \Rightarrow a])) (AHead a0 a3) (AHead a1 a2) H3) in (\lambda (H6: (eq A a0 
96 a1)).(eq_ind_r A a1 (\lambda (a: A).(aprem i a2 a)) (let H7 \def (eq_ind nat 
97 O (\lambda (ee: nat).(match ee in nat return (\lambda (_: nat).Prop) with [O 
98 \Rightarrow True | (S _) \Rightarrow False])) I (S i) H2) in (False_ind 
99 (aprem i a2 a1) H7)) a0 H6))) H4)))))) (\lambda (a0: A).(\lambda (a: 
100 A).(\lambda (i0: nat).(\lambda (H2: (aprem i0 a0 a)).(\lambda (H3: (((eq nat 
101 i0 (S i)) \to ((eq A a0 (AHead a1 a2)) \to (aprem i a2 a))))).(\lambda (a3: 
102 A).(\lambda (H4: (eq nat (S i0) (S i))).(\lambda (H5: (eq A (AHead a3 a0) 
103 (AHead a1 a2))).(let H6 \def (f_equal A A (\lambda (e: A).(match e in A 
104 return (\lambda (_: A).A) with [(ASort _ _) \Rightarrow a3 | (AHead a4 _) 
105 \Rightarrow a4])) (AHead a3 a0) (AHead a1 a2) H5) in ((let H7 \def (f_equal A 
106 A (\lambda (e: A).(match e in A return (\lambda (_: A).A) with [(ASort _ _) 
107 \Rightarrow a0 | (AHead _ a4) \Rightarrow a4])) (AHead a3 a0) (AHead a1 a2) 
108 H5) in (\lambda (_: (eq A a3 a1)).(let H9 \def (eq_ind A a0 (\lambda (a4: 
109 A).((eq nat i0 (S i)) \to ((eq A a4 (AHead a1 a2)) \to (aprem i a2 a)))) H3 
110 a2 H7) in (let H10 \def (eq_ind A a0 (\lambda (a4: A).(aprem i0 a4 a)) H2 a2 
111 H7) in (let H11 \def (f_equal nat nat (\lambda (e: nat).(match e in nat 
112 return (\lambda (_: nat).nat) with [O \Rightarrow i0 | (S n) \Rightarrow n])) 
113 (S i0) (S i) H4) in (let H12 \def (eq_ind nat i0 (\lambda (n: nat).((eq nat n 
114 (S i)) \to ((eq A a2 (AHead a1 a2)) \to (aprem i a2 a)))) H9 i H11) in (let 
115 H13 \def (eq_ind nat i0 (\lambda (n: nat).(aprem n a2 a)) H10 i H11) in 
116 H13))))))) H6)))))))))) y0 y x H1))) H0))) H))))).
117 (* COMMENTS
118 Initial nodes: 631
119 END *)
120