author | huffman |
Wed, 17 Aug 2011 14:32:48 -0700 | |
changeset 44256 | c478cd500dc4 |
parent 36409 | d323e7773aa8 |
child 47108 | 2a1953f0d20d |
permissions | -rw-r--r-- |
29823
0ab754d13ccd
session Reflecion renamed to Decision_Procs, moved Dense_Linear_Order there
haftmann
parents:
26160
diff
changeset
|
1 |
(* Author: Amine Chaieb, TU Muenchen *) |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
2 |
|
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
3 |
header {* Examples for Ferrante and Rackoff's quantifier elimination procedure *} |
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
4 |
|
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
5 |
theory Dense_Linear_Order_Ex |
30867 | 6 |
imports "~~/src/HOL/Decision_Procs/Dense_Linear_Order" |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
7 |
begin |
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
8 |
|
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
9 |
lemma |
36409 | 10 |
"\<exists>(y::'a::{linordered_field_inverse_zero, number_ring}) <2. x + 3* y < 0 \<and> x - y >0" |
23905 | 11 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
12 |
|
36409 | 13 |
lemma "~ (ALL x (y::'a::{linordered_field_inverse_zero, number_ring}). x < y --> 10*x < 11*y)" |
23905 | 14 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
15 |
|
36409 | 16 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. x < y --> (10*(x + 5*y + -1) < 60*y)" |
23905 | 17 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
18 |
|
36409 | 19 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y. x ~= y --> x < y" |
23905 | 20 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
21 |
|
36409 | 22 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y. (x ~= y & 10*x ~= 9*y & 10*x < y) --> x < y" |
23905 | 23 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
24 |
|
36409 | 25 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. (x ~= y & 5*x <= y) --> 500*x <= 100*y" |
23905 | 26 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
27 |
|
36409 | 28 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX (y::'a::{linordered_field_inverse_zero, number_ring}). 4*x + 3*y <= 0 & 4*x + 3*y >= -1)" |
23905 | 29 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
30 |
|
36409 | 31 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) < 0. (EX (y::'a::{linordered_field_inverse_zero, number_ring}) > 0. 7*x + y > 0 & x - y <= 9)" |
23905 | 32 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
33 |
|
36409 | 34 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}). (0 < x & x < 1) --> (ALL y > 1. x + y ~= 1)" |
23905 | 35 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
36 |
|
36409 | 37 |
lemma "EX x. (ALL (y::'a::{linordered_field_inverse_zero, number_ring}). y < 2 --> 2*(y - x) \<le> 0 )" |
23905 | 38 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
39 |
|
36409 | 40 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). x < 10 | x > 20 | (EX y. y>= 0 & y <= 10 & x+y = 20)" |
23905 | 41 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
42 |
|
36409 | 43 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y z. x + y < z --> y >= z --> x < 0" |
23905 | 44 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
45 |
|
36409 | 46 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z. x + 7*y < 5* z & 5*y >= 7*z & x < 0" |
23905 | 47 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
48 |
|
36409 | 49 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y z. abs (x + y) <= z --> (abs z = z)" |
23905 | 50 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
51 |
|
36409 | 52 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z. x + 7*y - 5* z < 0 & 5*y + 7*z + 3*x < 0" |
23905 | 53 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
54 |
|
36409 | 55 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y z. (abs (5*x+3*y+z) <= 5*x+3*y+z & abs (5*x+3*y+z) >= - (5*x+3*y+z)) | (abs (5*x+3*y+z) >= 5*x+3*y+z & abs (5*x+3*y+z) <= - (5*x+3*y+z))" |
23905 | 56 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
57 |
|
36409 | 58 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. x < y --> (EX z>0. x+z = y)" |
23905 | 59 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
60 |
|
36409 | 61 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. x < y --> (EX z>0. x+z = y)" |
23905 | 62 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
63 |
|
36409 | 64 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. (EX z>0. abs (x - y) <= z )" |
23905 | 65 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
66 |
|
36409 | 67 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y. (ALL z<0. (z < x --> z <= y) & (z > y --> z >= x))" |
23905 | 68 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
69 |
|
36409 | 70 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y. (ALL z>=0. abs (3*x+7*y) <= 2*z + 1)" |
23905 | 71 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
72 |
|
36409 | 73 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y. (ALL z<0. (z < x --> z <= y) & (z > y --> z >= x))" |
23905 | 74 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
75 |
|
36409 | 76 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring})>0. (ALL y. (EX z. 13* abs z \<noteq> abs (12*y - x) & 5*x - 3*(abs y) <= 7*z))" |
23905 | 77 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
78 |
|
36409 | 79 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}). abs (4*x + 17) < 4 & (ALL y . abs (x*34 - 34*y - 9) \<noteq> 0 \<longrightarrow> (EX z. 5*x - 3*abs y <= 7*z))" |
23905 | 80 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
81 |
|
36409 | 82 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y > abs (23*x - 9). (ALL z > abs (3*y - 19* abs x). x+z > 2*y))" |
23905 | 83 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
84 |
|
36409 | 85 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y< abs (3*x - 1). (ALL z >= (3*abs x - 1). abs (12*x - 13*y + 19*z) > abs (23*x) ))" |
23905 | 86 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
87 |
|
36409 | 88 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}). abs x < 100 & (ALL y > x. (EX z<2*y - x. 5*x - 3*y <= 7*z))" |
23905 | 89 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
90 |
|
36409 | 91 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y z w. 7*x<3*y --> 5*y < 7*z --> z < 2*w --> 7*(2*w-x) > 2*y" |
23905 | 92 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
93 |
|
36409 | 94 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z w. 5*x + 3*z - 17*w + abs (y - 8*x + z) <= 89" |
23905 | 95 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
96 |
|
36409 | 97 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z w. 5*x + 3*z - 17*w + 7* (y - 8*x + z) <= max y (7*z - x + w)" |
23905 | 98 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
99 |
|
36409 | 100 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z w. min (5*x + 3*z) (17*w) + 5* abs (y - 8*x + z) <= max y (7*z - x + w)" |
23905 | 101 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
102 |
|
36409 | 103 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y z. (EX w >= (x+y+z). w <= abs x + abs y + abs z)" |
23905 | 104 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
105 |
|
36409 | 106 |
lemma "~(ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y z w. 3* x + z*4 = 3*y & x + y < z & x> w & 3*x < w + y))" |
23905 | 107 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
108 |
|
36409 | 109 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. (EX z w. abs (x-y) = (z-w) & z*1234 < 233*x & w ~= y)" |
23905 | 110 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
111 |
|
36409 | 112 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y z w. min (5*x + 3*z) (17*w) + 5* abs (y - 8*x + z) <= max y (7*z - x + w))" |
23905 | 113 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
114 |
|
36409 | 115 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z. (ALL w >= abs (x+y+z). w >= abs x + abs y + abs z)" |
23905 | 116 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
117 |
|
36409 | 118 |
lemma "EX z. (ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. (EX w >= (x+y+z). w <= abs x + abs y + abs z))" |
23905 | 119 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
120 |
|
36409 | 121 |
lemma "EX z. (ALL (x::'a::{linordered_field_inverse_zero, number_ring}) < abs z. (EX y w. x< y & x < z & x> w & 3*x < w + y))" |
23905 | 122 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
123 |
|
36409 | 124 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}) y. (EX z. (ALL w. abs (x-y) = abs (z-w) --> z < x & w ~= y))" |
23905 | 125 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
126 |
|
36409 | 127 |
lemma "EX y. (ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX z w. min (5*x + 3*z) (17*w) + 5* abs (y - 8*x + z) <= max y (7*z - x + w)))" |
23905 | 128 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
129 |
|
36409 | 130 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) z. (ALL w >= 13*x - 4*z. (EX y. w >= abs x + abs y + z))" |
23905 | 131 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
132 |
|
36409 | 133 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}). (ALL y < x. (EX z > (x+y). |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
134 |
(ALL w. 5*w + 10*x - z >= y --> w + 7*x + 3*z >= 2*y)))" |
23905 | 135 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
136 |
|
36409 | 137 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}). (ALL y. (EX z > y. |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
138 |
(ALL w . w < 13 --> w + 10*x - z >= y --> 5*w + 7*x + 13*z >= 2*y)))" |
23905 | 139 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
140 |
|
36409 | 141 |
lemma "EX (x::'a::{linordered_field_inverse_zero, number_ring}) y z w. min (5*x + 3*z) (17*w) + 5* abs (y - 8*x + z) <= max y (7*z - x + w)" |
23905 | 142 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
143 |
|
36409 | 144 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y. (ALL z>19. y <= x + z & (EX w. abs (y - x) < w)))" |
23905 | 145 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
146 |
|
36409 | 147 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y. (ALL z>19. y <= x + z & (EX w. abs (x + z) < w - y)))" |
23905 | 148 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
149 |
|
36409 | 150 |
lemma "ALL (x::'a::{linordered_field_inverse_zero, number_ring}). (EX y. abs y ~= abs x & (ALL z> max x y. (EX w. w ~= y & w ~= z & 3*w - z >= x + y)))" |
23905 | 151 |
by ferrack |
23454
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
152 |
|
c54975167be9
replaced Real/Ferrante-Rackoff tool by generic version in Main HOL;
wenzelm
parents:
diff
changeset
|
153 |
end |