author | paulson |
Fri, 05 Nov 1999 12:45:37 +0100 | |
changeset 7999 | 7acf6eb8eec1 |
parent 6498 | 1ebbe18fe236 |
child 9867 | bf8300fa4238 |
permissions | -rw-r--r-- |
3302 | 1 |
(* Title: TFL/thms |
2 |
ID: $Id$ |
|
3 |
Author: Konrad Slind, Cambridge University Computer Laboratory |
|
4 |
Copyright 1997 University of Cambridge |
|
5 |
*) |
|
6 |
||
2112 | 7 |
structure Thms : Thms_sig = |
8 |
struct |
|
6498 | 9 |
val WFREC_COROLLARY = get_thm WF.thy "tfl_wfrec" |
10 |
val WF_INDUCTION_THM = get_thm WF.thy "tfl_wf_induct" |
|
2112 | 11 |
val CUT_DEF = cut_def |
12 |
||
13 |
local val _ = goal HOL.thy "!P x. P x --> P (Eps P)" |
|
14 |
val _ = by (strip_tac 1) |
|
15 |
val _ = by (rtac selectI 1) |
|
16 |
val _ = by (assume_tac 1) |
|
17 |
in val SELECT_AX = result() |
|
18 |
end; |
|
19 |
||
20 |
(*------------------------------------------------------------------------- |
|
3458
5ff4bfab859c
Removal of COND_CONG, which is just if_cong RS eq_reflection
paulson
parents:
3302
diff
changeset
|
21 |
* Congruence rule needed for TFL, but not for general simplification |
2112 | 22 |
*-------------------------------------------------------------------------*) |
23 |
local val [p1,p2] = goal HOL.thy "(M = N) ==> \ |
|
24 |
\ (!!x. ((x = N) ==> (f x = g x))) ==> \ |
|
25 |
\ (Let M f = Let N g)"; |
|
26 |
val _ = by (simp_tac (HOL_ss addsimps[Let_def,p1]) 1); |
|
27 |
val _ = by (rtac p2 1); |
|
28 |
val _ = by (rtac refl 1); |
|
3458
5ff4bfab859c
Removal of COND_CONG, which is just if_cong RS eq_reflection
paulson
parents:
3302
diff
changeset
|
29 |
in val LET_CONG = result() end; |
2112 | 30 |
|
3273 | 31 |
fun prove s = prove_goal HOL.thy s (fn _ => [fast_tac HOL_cs 1]); |
2112 | 32 |
|
3273 | 33 |
val eqT = prove"(x = True) --> x" |
34 |
val rev_eq_mp = prove"(x = y) --> y --> x" |
|
35 |
val simp_thm = prove"(x-->y) --> (x = x') --> (x' --> y)" |
|
2112 | 36 |
|
37 |
end; |