src/HOL/Codatatype/Tools/bnf_sugar_tactics.ML
author blanchet
Thu, 30 Aug 2012 13:42:05 +0200
changeset 50043 487427a02bee
parent 50037 005ce926a932
child 50044 f0ecfa9575a9
permissions -rw-r--r--
generate "disc_distinct" theorems
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;