author | wenzelm |
Tue, 18 Jul 2000 21:08:57 +0200 | |
changeset 9385 | 6e1ac1629ac7 |
parent 8622 | 870a58dd0ddd |
child 9640 | 8c6cf4f01644 |
permissions | -rw-r--r-- |
3302 | 1 |
(* Title: TFL/tfl |
2 |
ID: $Id$ |
|
3 |
Author: Konrad Slind, Cambridge University Computer Laboratory |
|
4 |
Copyright 1997 University of Cambridge |
|
5 |
||
3391
5e45dd3b64e9
More de-HOLification: using Free, Const, etc. instead of mk_var, mk_const
paulson
parents:
3333
diff
changeset
|
6 |
Main module |
3302 | 7 |
*) |
8 |
||
2112 | 9 |
signature TFL_sig = |
10 |
sig |
|
6498 | 11 |
|
12 |
val trace : bool ref |
|
13 |
||
14 |
val default_simps : thm list (*simprules used for deriving rules...*) |
|
15 |
||
16 |
val congs : thm list -> thm list (*fn to make congruent rules*) |
|
17 |
||
8622
870a58dd0ddd
the simplification rules returned from TFL are now paired with the row they
nipkow
parents:
6498
diff
changeset
|
18 |
type pattern |
2112 | 19 |
|
3391
5e45dd3b64e9
More de-HOLification: using Free, Const, etc. instead of mk_var, mk_const
paulson
parents:
3333
diff
changeset
|
20 |
val mk_functional : theory -> term list |
3245
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
21 |
-> {functional:term, |
2112 | 22 |
pats: pattern list} |
23 |
||
3405 | 24 |
val wfrec_definition0 : theory -> string -> term -> term -> theory |
3191 | 25 |
|
6498 | 26 |
val post_definition : thm list -> theory * (thm * pattern list) |
27 |
-> {theory : theory, |
|
8622
870a58dd0ddd
the simplification rules returned from TFL are now paired with the row they
nipkow
parents:
6498
diff
changeset
|
28 |
rules : thm, |
870a58dd0ddd
the simplification rules returned from TFL are now paired with the row they
nipkow
parents:
6498
diff
changeset
|
29 |
rows : int list, |
3405 | 30 |
TCs : term list list, |
8622
870a58dd0ddd
the simplification rules returned from TFL are now paired with the row they
nipkow
parents:
6498
diff
changeset
|
31 |
full_pats_TCs : (term * term list) list} |
3191 | 32 |
|
6498 | 33 |
val wfrec_eqns : theory -> xstring |
34 |
-> thm list (* congruence rules *) |
|
35 |
-> term list |
|
36 |
-> {WFR : term, SV : term list, |
|
3245
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
37 |
proto_def : term, |
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
38 |
extracta :(thm * term list) list, |
2112 | 39 |
pats : pattern list} |
40 |
||
6498 | 41 |
val lazyR_def : theory -> xstring |
42 |
-> thm list (* congruence rules *) |
|
3391
5e45dd3b64e9
More de-HOLification: using Free, Const, etc. instead of mk_var, mk_const
paulson
parents:
3333
diff
changeset
|
43 |
-> term list |
6498 | 44 |
-> {theory : theory, |
45 |
rules : thm, |
|
46 |
R : term, |
|
47 |
SV : term list, |
|
48 |
full_pats_TCs : (term * term list) list, |
|
49 |
patterns : pattern list} |
|
2112 | 50 |
|
6498 | 51 |
val mk_induction : theory |
52 |
-> {fconst:term, |
|
53 |
R : term, |
|
54 |
SV : term list, |
|
55 |
pat_TCs_list : (term * term list) list} |
|
56 |
-> thm |
|
2112 | 57 |
|
3245
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
58 |
val postprocess: {WFtac:tactic, terminator:tactic, simplifier:cterm -> thm} |
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
59 |
-> theory |
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
60 |
-> {rules:thm, induction:thm, TCs:term list list} |
241838c01caf
Removal of redundant code (unused or already present in Isabelle.
paulson
parents:
3191
diff
changeset
|
61 |
-> {rules:thm, induction:thm, nested_tcs:thm list} |
2112 | 62 |
end; |