1 (* This file was generated by coqgen *)
8 (* extensions for ex2 *)
10 Syntactic Definition ex2_intro := ex_intro2.
12 Theorem ex2_sym: (A:Set; P,Q:A->Prop)
13 (EX x | (P x) & (Q x)) -> (EX x | (Q x) & (P x)).
14 Intros; XElim H; XEAuto.
17 Hints Resolve ex2_sym : ltlc.
21 Inductive or3 [P0,P1,P2:Prop] : Prop :=
22 | or3_intro0 : P0 -> (or3 P0 P1 P2)
23 | or3_intro1 : P1 -> (or3 P0 P1 P2)
24 | or3_intro2 : P2 -> (or3 P0 P1 P2).
26 Hint or3 : ltlc := Constructors or3.
28 Grammar constr constr10 :=
30 [ "OR" constr($c0) "|" constr($c1) "|" constr($c2) ] ->
31 [ (or3 $c0 $c1 $c2) ].
35 Inductive or4 [P0,P1,P2,P3:Prop] : Prop :=
36 | or4_intro0 : P0 -> (or4 P0 P1 P2 P3)
37 | or4_intro1 : P1 -> (or4 P0 P1 P2 P3)
38 | or4_intro2 : P2 -> (or4 P0 P1 P2 P3)
39 | or4_intro3 : P3 -> (or4 P0 P1 P2 P3).
41 Hint or4 : ltlc := Constructors or4.
43 Grammar constr constr10 :=
45 [ "OR" constr($c0) "|" constr($c1) "|" constr($c2) "|" constr($c3) ] ->
46 [ (or4 $c0 $c1 $c2 $c3) ].
50 Inductive ex2_2 [A0,A1:Set; P0,P1:A0->A1->Prop] : Prop :=
51 ex2_2_intro : (x0:A0; x1:A1)(P0 x0 x1)->(P1 x0 x1)->(ex2_2 A0 A1 P0 P1).
53 Hint ex2_2 : ltlc := Constructors ex2_2.
55 Syntactic Definition Ex2_2 := ex2_2 | 1.
57 Grammar constr constr10 :=
59 [ "EX" ident($v0) ident($v1) "|" constr($c0) "&" constr($c1) ] ->
60 [ (ex2_2 ? ? [$v0;$v1]$c0 [$v0;$v1]$c1) ].
64 Inductive ex3_2 [A0,A1:Set; P0,P1,P2:A0->A1->Prop] : Prop :=
65 ex3_2_intro : (x0:A0; x1:A1)(P0 x0 x1)->(P1 x0 x1)->(P2 x0 x1)->(ex3_2 A0 A1 P0 P1 P2).
67 Hint ex3_2 : ltlc := Constructors ex3_2.
69 Syntactic Definition Ex3_2 := ex3_2 | 1.
71 Grammar constr constr10 :=
73 [ "EX" ident($v0) ident($v1) "|" constr($c0) "&" constr($c1) "&" constr($c2) ] ->
74 [ (ex3_2 ? ? [$v0;$v1]$c0 [$v0;$v1]$c1 [$v0;$v1]$c2) ].
78 Inductive ex3_3 [A0,A1,A2:Set; P0,P1,P2:A0->A1->A2->Prop] : Prop :=
79 ex3_3_intro : (x0:A0; x1:A1; x2:A2)(P0 x0 x1 x2)->(P1 x0 x1 x2)->(P2 x0 x1 x2)->(ex3_3 A0 A1 A2 P0 P1 P2).
81 Hint ex3_3 : ltlc := Constructors ex3_3.
83 Syntactic Definition Ex3_3 := ex3_3 | 1.
85 Grammar constr constr10 :=
87 [ "EX" ident($v0) ident($v1) ident($v2) "|" constr($c0) "&" constr($c1) "&" constr($c2) ] ->
88 [ (ex3_3 ? ? ? [$v0;$v1;$v2]$c0 [$v0;$v1;$v2]$c1 [$v0;$v1;$v2]$c2) ].
92 Inductive ex4_3 [A0,A1,A2:Set; P0,P1,P2,P3:A0->A1->A2->Prop] : Prop :=
93 ex4_3_intro : (x0:A0; x1:A1; x2:A2)(P0 x0 x1 x2)->(P1 x0 x1 x2)->(P2 x0 x1 x2)->(P3 x0 x1 x2)->(ex4_3 A0 A1 A2 P0 P1 P2 P3).
95 Hint ex4_3 : ltlc := Constructors ex4_3.
97 Syntactic Definition Ex4_3 := ex4_3 | 1.
99 Grammar constr constr10 :=
101 [ "EX" ident($v0) ident($v1) ident($v2) "|" constr($c0) "&" constr($c1) "&" constr($c2) "&" constr($c3) ] ->
102 [ (ex4_3 ? ? ? [$v0;$v1;$v2]$c0 [$v0;$v1;$v2]$c1 [$v0;$v1;$v2]$c2 [$v0;$v1;$v2]$c3) ].
106 Inductive ex3_4 [A0,A1,A2,A3:Set; P0,P1,P2:A0->A1->A2->A3->Prop] : Prop :=
107 ex3_4_intro : (x0:A0; x1:A1; x2:A2; x3:A3)(P0 x0 x1 x2 x3)->(P1 x0 x1 x2 x3)->(P2 x0 x1 x2 x3)->(ex3_4 A0 A1 A2 A3 P0 P1 P2).
109 Hint ex3_4 : ltlc := Constructors ex3_4.
111 Syntactic Definition Ex3_4 := ex3_4 | 1.
113 Grammar constr constr10 :=
115 [ "EX" ident($v0) ident($v1) ident($v2) ident($v3) "|" constr($c0) "&" constr($c1) "&" constr($c2) ] ->
116 [ (ex3_4 ? ? ? ? [$v0;$v1;$v2;$v3]$c0 [$v0;$v1;$v2;$v3]$c1 [$v0;$v1;$v2;$v3]$c2) ].
120 Inductive ex4_4 [A0,A1,A2,A3:Set; P0,P1,P2,P3:A0->A1->A2->A3->Prop] : Prop :=
121 ex4_4_intro : (x0:A0; x1:A1; x2:A2; x3:A3)(P0 x0 x1 x2 x3)->(P1 x0 x1 x2 x3)->(P2 x0 x1 x2 x3)->(P3 x0 x1 x2 x3)->(ex4_4 A0 A1 A2 A3 P0 P1 P2 P3).
123 Hint ex4_4 : ltlc := Constructors ex4_4.
125 Syntactic Definition Ex4_4 := ex4_4 | 1.
127 Grammar constr constr10 :=
129 [ "EX" ident($v0) ident($v1) ident($v2) ident($v3) "|" constr($c0) "&" constr($c1) "&" constr($c2) "&" constr($c3) ] ->
130 [ (ex4_4 ? ? ? ? [$v0;$v1;$v2;$v3]$c0 [$v0;$v1;$v2;$v3]$c1 [$v0;$v1;$v2;$v3]$c2 [$v0;$v1;$v2;$v3]$c3) ].
134 Inductive ex4_5 [A0,A1,A2,A3,A4:Set; P0,P1,P2,P3:A0->A1->A2->A3->A4->Prop] : Prop :=
135 ex4_5_intro : (x0:A0; x1:A1; x2:A2; x3:A3; x4:A4)(P0 x0 x1 x2 x3 x4)->(P1 x0 x1 x2 x3 x4)->(P2 x0 x1 x2 x3 x4)->(P3 x0 x1 x2 x3 x4)->(ex4_5 A0 A1 A2 A3 A4 P0 P1 P2 P3).
137 Hint ex4_5 : ltlc := Constructors ex4_5.
139 Syntactic Definition Ex4_5 := ex4_5 | 1.
141 Grammar constr constr10 :=
143 [ "EX" ident($v0) ident($v1) ident($v2) ident($v3) ident($v4) "|" constr($c0) "&" constr($c1) "&" constr($c2) "&" constr($c3) ] ->
144 [ (ex4_5 ? ? ? ? ? [$v0;$v1;$v2;$v3;$v4]$c0 [$v0;$v1;$v2;$v3;$v4]$c1 [$v0;$v1;$v2;$v3;$v4]$c2 [$v0;$v1;$v2;$v3;$v4]$c3) ].
148 Inductive ex6_6 [A0,A1,A2,A3,A4,A5:Set; P0,P1,P2,P3,P4,P5:A0->A1->A2->A3->A4->A5->Prop] : Prop :=
149 ex6_6_intro : (x0:A0; x1:A1; x2:A2; x3:A3; x4:A4; x5:A5)(P0 x0 x1 x2 x3 x4 x5)->(P1 x0 x1 x2 x3 x4 x5)->(P2 x0 x1 x2 x3 x4 x5)->(P3 x0 x1 x2 x3 x4 x5)->(P4 x0 x1 x2 x3 x4 x5)->(P5 x0 x1 x2 x3 x4 x5)->(ex6_6 A0 A1 A2 A3 A4 A5 P0 P1 P2 P3 P4 P5).
151 Hint ex6_6 : ltlc := Constructors ex6_6.
153 Syntactic Definition Ex6_6 := ex6_6 | 1.
155 Grammar constr constr10 :=
157 [ "EX" ident($v0) ident($v1) ident($v2) ident($v3) ident($v4) ident($v5) "|" constr($c0) "&" constr($c1) "&" constr($c2) "&" constr($c3) "&" constr($c4) "&" constr($c5) ] ->
158 [ (ex6_6 ? ? ? ? ? ? [$v0;$v1;$v2;$v3;$v4;$v5]$c0 [$v0;$v1;$v2;$v3;$v4;$v5]$c1 [$v0;$v1;$v2;$v3;$v4;$v5]$c2 [$v0;$v1;$v2;$v3;$v4;$v5]$c3 [$v0;$v1;$v2;$v3;$v4;$v5]$c4 [$v0;$v1;$v2;$v3;$v4;$v5]$c5) ].