author | blanchet |
Thu, 30 Aug 2012 13:42:05 +0200 | |
changeset 50043 | 487427a02bee |
parent 50037 | 005ce926a932 |
child 50044 | f0ecfa9575a9 |
permissions | -rw-r--r-- |
blanchet@50035 | 1 |
(* Title: HOL/Codatatype/Tools/bnf_sugar_tactics.ML |
blanchet@50035 | 2 |
Author: Jasmin Blanchette, TU Muenchen |
blanchet@50035 | 3 |
Copyright 2012 |
blanchet@50035 | 4 |
|
blanchet@50035 | 5 |
Tactics for sugar on top of a BNF. |
blanchet@50035 | 6 |
*) |
blanchet@50035 | 7 |
|
blanchet@50035 | 8 |
signature BNF_SUGAR_TACTICS = |
blanchet@50035 | 9 |
sig |
blanchet@50035 | 10 |
val mk_nchotomy_tac: int -> thm -> tactic |
blanchet@50043 | 11 |
val mk_half_disc_disjoint_tac: int -> thm -> thm -> tactic |
blanchet@50043 | 12 |
val mk_other_half_disc_disjoint_tac: thm -> tactic |
blanchet@50035 | 13 |
end; |
blanchet@50035 | 14 |
|
blanchet@50035 | 15 |
structure BNF_Sugar_Tactics : BNF_SUGAR_TACTICS = |
blanchet@50035 | 16 |
struct |
blanchet@50035 | 17 |
|
blanchet@50035 | 18 |
open BNF_FP_Util |
blanchet@50035 | 19 |
|
blanchet@50035 | 20 |
fun mk_nchotomy_tac n exhaust = |
blanchet@50035 | 21 |
(rtac allI THEN' rtac exhaust THEN' |
blanchet@50037 | 22 |
EVERY' (maps (fn k => [rtac (mk_disjIN n k), REPEAT_DETERM o rtac exI, atac]) (1 upto n))) 1; |
blanchet@50035 | 23 |
|
blanchet@50043 | 24 |
fun mk_half_disc_disjoint_tac m disc_def disc'_thm = |
blanchet@50043 | 25 |
(dtac (disc_def RS iffD1) THEN' |
blanchet@50043 | 26 |
REPEAT_DETERM_N m o etac exE THEN' |
blanchet@50043 | 27 |
hyp_subst_tac THEN' |
blanchet@50043 | 28 |
rtac disc'_thm) 1; |
blanchet@50043 | 29 |
|
blanchet@50043 | 30 |
fun mk_other_half_disc_disjoint_tac half_thm = |
blanchet@50043 | 31 |
(etac @{thm contrapos_pn} THEN' etac half_thm) 1; |
blanchet@50043 | 32 |
|
blanchet@50035 | 33 |
end; |