1459
|
1 |
(* Title: FOLP/ex/if
|
0
|
2 |
ID: $Id$
|
1459
|
3 |
Author: Lawrence C Paulson, Cambridge University Computer Laboratory
|
0
|
4 |
Copyright 1991 University of Cambridge
|
|
5 |
|
|
6 |
For ex/if.thy. First-Order Logic: the 'if' example
|
|
7 |
*)
|
|
8 |
|
|
9 |
open If;
|
|
10 |
open Cla; (*in case structure Int is open!*)
|
|
11 |
|
|
12 |
val prems = goalw If.thy [if_def]
|
3836
|
13 |
"[| !!x. x:P ==> f(x):Q; !!x. x:~P ==> g(x):R |] ==> ?p:if(P,Q,R)";
|
0
|
14 |
by (fast_tac (FOLP_cs addIs prems) 1);
|
|
15 |
val ifI = result();
|
|
16 |
|
|
17 |
val major::prems = goalw If.thy [if_def]
|
|
18 |
"[| p:if(P,Q,R); !!x y.[| x:P; y:Q |] ==> f(x,y):S; \
|
|
19 |
\ !!x y.[| x:~P; y:R |] ==> g(x,y):S |] ==> ?p:S";
|
|
20 |
by (cut_facts_tac [major] 1);
|
|
21 |
by (fast_tac (FOLP_cs addIs prems) 1);
|
|
22 |
val ifE = result();
|
|
23 |
|
|
24 |
|
5061
|
25 |
Goal
|
0
|
26 |
"?p : if(P, if(Q,A,B), if(Q,C,D)) <-> if(Q, if(P,A,C), if(P,B,D))";
|
1459
|
27 |
by (rtac iffI 1);
|
|
28 |
by (etac ifE 1);
|
|
29 |
by (etac ifE 1);
|
|
30 |
by (rtac ifI 1);
|
|
31 |
by (rtac ifI 1);
|
0
|
32 |
|
|
33 |
choplev 0;
|
|
34 |
val if_cs = FOLP_cs addSIs [ifI] addSEs[ifE];
|
|
35 |
by (fast_tac if_cs 1);
|
|
36 |
val if_commute = result();
|
|
37 |
|
|
38 |
|
5061
|
39 |
Goal "?p : if(if(P,Q,R), A, B) <-> if(P, if(Q,A,B), if(R,A,B))";
|
0
|
40 |
by (fast_tac if_cs 1);
|
|
41 |
val nested_ifs = result();
|
|
42 |
|
|
43 |
writeln"Reached end of file.";
|