src/Pure/conjunction.ML
author wenzelm
Sat, 15 May 2010 23:40:00 +0200
changeset 36953 2af1ad9aa1a3
parent 35985 0bbf0d2348f9
child 43329 84472e198515
permissions -rw-r--r--
renamed structure OuterSyntax to Outer_Syntax, keeping the old name as alias for some time;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/conjunction.ML
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     3
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     4
Meta-level conjunction.
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     5
*)
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     6
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     7
signature CONJUNCTION =
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     8
sig
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
     9
  val conjunction: cterm
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    10
  val mk_conjunction: cterm * cterm -> cterm
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    11
  val mk_conjunction_balanced: cterm list -> cterm
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    12
  val dest_conjunction: cterm -> cterm * cterm
30823
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    13
  val dest_conjunctions: cterm -> cterm list
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    14
  val cong: thm -> thm -> thm
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    15
  val convs: (cterm -> thm) -> cterm -> thm
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    16
  val conjunctionD1: thm
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    17
  val conjunctionD2: thm
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    18
  val conjunctionI: thm
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    19
  val intr: thm -> thm -> thm
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    20
  val intr_balanced: thm list -> thm
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    21
  val elim: thm -> thm * thm
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    22
  val elim_balanced: int -> thm -> thm list
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    23
  val curry_balanced: int -> thm -> thm
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    24
  val uncurry_balanced: int -> thm -> thm
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    25
end;
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    26
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    27
structure Conjunction: CONJUNCTION =
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    28
struct
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    29
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    30
(** abstract syntax **)
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    31
26485
b90d1fc201de certify wrt. dynamic context;
wenzelm
parents: 26424
diff changeset
    32
fun certify t = Thm.cterm_of (Context.the_theory (Context.the_thread_data ())) t;
33384
1b5ba4e6a953 modernized structure Simple_Syntax;
wenzelm
parents: 33277
diff changeset
    33
val read_prop = certify o Simple_Syntax.read_prop;
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    34
26485
b90d1fc201de certify wrt. dynamic context;
wenzelm
parents: 26424
diff changeset
    35
val true_prop = certify Logic.true_prop;
b90d1fc201de certify wrt. dynamic context;
wenzelm
parents: 26424
diff changeset
    36
val conjunction = certify Logic.conjunction;
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    37
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    38
fun mk_conjunction (A, B) = Thm.capply (Thm.capply conjunction A) B;
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    39
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    40
fun mk_conjunction_balanced [] = true_prop
32765
3032c0308019 modernized Balanced_Tree;
wenzelm
parents: 30823
diff changeset
    41
  | mk_conjunction_balanced ts = Balanced_Tree.make mk_conjunction ts;
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    42
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    43
fun dest_conjunction ct =
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    44
  (case Thm.term_of ct of
26424
a6cad32a27b0 eliminated theory ProtoPure;
wenzelm
parents: 24976
diff changeset
    45
    (Const ("Pure.conjunction", _) $ _ $ _) => Thm.dest_binop ct
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    46
  | _ => raise TERM ("dest_conjunction", [Thm.term_of ct]));
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    47
30823
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    48
fun dest_conjunctions ct =
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    49
  (case try dest_conjunction ct of
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    50
    NONE => [ct]
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    51
  | SOME (A, B) => dest_conjunctions A @ dest_conjunctions B);
eb99b9134f2e added dest_conjunctions (cf. Logic.dest_conjunctions);
wenzelm
parents: 29606
diff changeset
    52
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    53
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    54
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    55
(** derived rules **)
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    56
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    57
(* conversion *)
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    58
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    59
val cong = Thm.combination o Thm.combination (Thm.reflexive conjunction);
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    60
23422
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    61
fun convs cv ct =
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    62
  (case try dest_conjunction ct of
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    63
    NONE => cv ct
4a368c087f58 balanced conjunctions;
wenzelm
parents: 21565
diff changeset
    64
  | SOME (A, B) => cong (convs cv A) (convs cv B));
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    65
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    66
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    67
(* intro/elim *)
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    68
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    69
local
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    70
24241
424cb8b5e5b4 SimpleSyntax.read_prop;
wenzelm
parents: 23535
diff changeset
    71
val A = read_prop "A" and vA = read_prop "?A";
424cb8b5e5b4 SimpleSyntax.read_prop;
wenzelm
parents: 23535
diff changeset
    72
val B = read_prop "B" and vB = read_prop "?B";
424cb8b5e5b4 SimpleSyntax.read_prop;
wenzelm
parents: 23535
diff changeset
    73
val C = read_prop "C";
424cb8b5e5b4 SimpleSyntax.read_prop;
wenzelm
parents: 23535
diff changeset
    74
val ABC = read_prop "A ==> B ==> C";
28856
5e009a80fe6d Pure syntax: more coherent treatment of aprop, permanent TERM and &&&;
wenzelm
parents: 28674
diff changeset
    75
val A_B = read_prop "A &&& B";
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    76
26424
a6cad32a27b0 eliminated theory ProtoPure;
wenzelm
parents: 24976
diff changeset
    77
val conjunction_def =
35845
e5980f0ad025 renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents: 33384
diff changeset
    78
  Thm.unvarify_global
e5980f0ad025 renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents: 33384
diff changeset
    79
    (Thm.axiom (Context.the_theory (Context.the_thread_data ())) "Pure.conjunction_def");
19416
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    80
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    81
fun conjunctionD which =
4198e7698f6a Meta-level conjunction.
wenzelm
parents:
diff changeset
    82
  Drule.implies_intr_list [A, B] (Thm.assume (which (A, B))) COMP