src/HOL/Prolog/prolog.ML
author wenzelm
Sun, 18 Feb 2024 15:03:47 +0100
changeset 79662 dca6ea3b7a01
parent 76091 922e3f9251ac
permissions -rw-r--r--
clarified signature: more explicit types;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     1
(*  Title:    HOL/Prolog/prolog.ML
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     2
    Author:   David von Oheimb (based on a lecture on Lambda Prolog by Nadathur)
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     3
*)
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     4
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     5
structure Prolog =
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     6
struct
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     7
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     8
exception not_HOHH;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
     9
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    10
fun isD t = case t of
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    11
    Const(\<^const_name>\<open>Trueprop\<close>,_)$t     => isD t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    12
  | Const(\<^const_name>\<open>HOL.conj\<close>  ,_)$l$r     => isD l andalso isD r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    13
  | Const(\<^const_name>\<open>HOL.implies\<close>,_)$l$r     => isG l andalso isD r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    14
  | Const(\<^const_name>\<open>Pure.imp\<close>,_)$l$r     => isG l andalso isD r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    15
  | Const(\<^const_name>\<open>All\<close>,_)$Abs(s,_,t) => isD t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    16
  | Const(\<^const_name>\<open>Pure.all\<close>,_)$Abs(s,_,t) => isD t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    17
  | Const(\<^const_name>\<open>HOL.disj\<close>,_)$_$_       => false
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    18
  | Const(\<^const_name>\<open>Ex\<close> ,_)$_          => false
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    19
  | Const(\<^const_name>\<open>Not\<close>,_)$_          => false
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    20
  | Const(\<^const_name>\<open>True\<close>,_)           => false
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    21
  | Const(\<^const_name>\<open>False\<close>,_)          => false
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    22
  | l $ r                     => isD l
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    23
  | Const _ (* rigid atom *)  => true
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    24
  | Bound _ (* rigid atom *)  => true
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    25
  | Free  _ (* rigid atom *)  => true
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    26
  | _    (* flexible atom,
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    27
            anything else *)  => false
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    28
and
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    29
    isG t = case t of
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    30
    Const(\<^const_name>\<open>Trueprop\<close>,_)$t     => isG t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    31
  | Const(\<^const_name>\<open>HOL.conj\<close>  ,_)$l$r     => isG l andalso isG r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    32
  | Const(\<^const_name>\<open>HOL.disj\<close>  ,_)$l$r     => isG l andalso isG r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    33
  | Const(\<^const_name>\<open>HOL.implies\<close>,_)$l$r     => isD l andalso isG r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    34
  | Const(\<^const_name>\<open>Pure.imp\<close>,_)$l$r     => isD l andalso isG r
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    35
  | Const(\<^const_name>\<open>All\<close>,_)$Abs(_,_,t) => isG t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    36
  | Const(\<^const_name>\<open>Pure.all\<close>,_)$Abs(_,_,t) => isG t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    37
  | Const(\<^const_name>\<open>Ex\<close> ,_)$Abs(_,_,t) => isG t
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    38
  | Const(\<^const_name>\<open>True\<close>,_)           => true
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    39
  | Const(\<^const_name>\<open>Not\<close>,_)$_          => false
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    40
  | Const(\<^const_name>\<open>False\<close>,_)          => false
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    41
  | _ (* atom *)              => true;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    42
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    43
val check_HOHH_tac1 = PRIMITIVE (fn thm =>
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    44
        if isG (Thm.concl_of thm) then thm else raise not_HOHH);
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    45
val check_HOHH_tac2 = PRIMITIVE (fn thm =>
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    46
        if forall isG (Thm.prems_of thm) then thm else raise not_HOHH);
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    47
fun check_HOHH thm  = (if isD (Thm.concl_of thm) andalso forall isG (Thm.prems_of thm)
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    48
                        then thm else raise not_HOHH);
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    49
55143
04448228381d explicit eigen-context for attributes "where", "of", and corresponding read_instantiate, instantiate_tac;
wenzelm
parents: 52233
diff changeset
    50
fun atomizeD ctxt thm =
04448228381d explicit eigen-context for attributes "where", "of", and corresponding read_instantiate, instantiate_tac;
wenzelm
parents: 52233
diff changeset
    51
  let
59582
0fbed69ff081 tuned signature -- prefer qualified names;
wenzelm
parents: 59498
diff changeset
    52
    fun at  thm = case Thm.concl_of thm of
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    53
      _$(Const(\<^const_name>\<open>All\<close> ,_)$Abs(s,_,_))=>
59755
f8d164ab0dc1 more position information;
wenzelm
parents: 59582
diff changeset
    54
        let val s' = if s="P" then "PP" else s in
f8d164ab0dc1 more position information;
wenzelm
parents: 59582
diff changeset
    55
          at(thm RS (Rule_Insts.read_instantiate ctxt [((("x", 0), Position.none), s')] [s'] spec))
f8d164ab0dc1 more position information;
wenzelm
parents: 59582
diff changeset
    56
        end
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    57
    | _$(Const(\<^const_name>\<open>HOL.conj\<close>,_)$_$_)       => at(thm RS conjunct1)@at(thm RS conjunct2)
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    58
    | _$(Const(\<^const_name>\<open>HOL.implies\<close>,_)$_$_)     => at(thm RS mp)
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    59
    | _                             => [thm]
55143
04448228381d explicit eigen-context for attributes "where", "of", and corresponding read_instantiate, instantiate_tac;
wenzelm
parents: 52233
diff changeset
    60
  in map zero_var_indexes (at thm) end;
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    61
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    62
val atomize_ss =
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    63
  (empty_simpset \<^context> |> Simplifier.set_mksimps (mksimps mksimps_pairs))
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    64
  addsimps [
45654
cf10bde35973 more antiquotations;
wenzelm
parents: 45625
diff changeset
    65
        @{thm all_conj_distrib}, (* "(! x. P x & Q x) = ((! x. P x) & (! x. Q x))" *)
46161
4ed94d92ae19 prefer antiquotations;
wenzelm
parents: 45654
diff changeset
    66
        @{thm imp_conjL} RS sym, (* "(D :- G1 :- G2) = (D :- G1 & G2)" *)
4ed94d92ae19 prefer antiquotations;
wenzelm
parents: 45654
diff changeset
    67
        @{thm imp_conjR},        (* "(D1 & D2 :- G) = ((D1 :- G) & (D2 :- G))" *)
52088
7d8b53e80ce7 proper run-time context;
wenzelm
parents: 52043
diff changeset
    68
        @{thm imp_all}]          (* "((!x. D) :- G) = (!x. D :- G)" *)
7d8b53e80ce7 proper run-time context;
wenzelm
parents: 52043
diff changeset
    69
  |> simpset_of;
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    70
45625
750c5a47400b modernized some old-style infix operations, which were left over from the time of ML proof scripts;
wenzelm
parents: 39125
diff changeset
    71
32283
3bebc195c124 qualified Subgoal.FOCUS;
wenzelm
parents: 32282
diff changeset
    72
(*val hyp_resolve_tac = Subgoal.FOCUS_PREMS (fn {prems, ...} =>
32260
eb97888fa422 eliminated METAHYPS;
wenzelm
parents: 32010
diff changeset
    73
                                  resolve_tac (maps atomizeD prems) 1);
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    74
  -- is nice, but cannot instantiate unknowns in the assumptions *)
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
    75
fun hyp_resolve_tac ctxt = SUBGOAL (fn (subgoal, i) =>
46473
a687b75f9fa8 more conventional tactic setup;
wenzelm
parents: 46161
diff changeset
    76
  let
69597
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    77
        fun ap (Const(\<^const_name>\<open>All\<close>,_)$Abs(_,_,t))=(case ap t of (k,a,t) => (k+1,a  ,t))
ff784d5a5bfb isabelle update -u control_cartouches;
wenzelm
parents: 60754
diff changeset
    78
        |   ap (Const(\<^const_name>\<open>HOL.implies\<close>,_)$_$t)    =(case ap t of (k,_,t) => (k,true ,t))
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    79
        |   ap t                          =                         (0,false,t);
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    80
(*
56245
84fc7dfa3cd4 more qualified names;
wenzelm
parents: 55151
diff changeset
    81
        fun rep_goal (Const (@{const_name Pure.all},_)$Abs (_,_,t)) = rep_goal t
84fc7dfa3cd4 more qualified names;
wenzelm
parents: 55151
diff changeset
    82
        |   rep_goal (Const (@{const_name Pure.imp},_)$s$t)         =
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    83
                        (case rep_goal t of (l,t) => (s::l,t))
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    84
        |   rep_goal t                             = ([]  ,t);
38557
9926c47ad1a1 more antiquotations
haftmann
parents: 38549
diff changeset
    85
        val (prems, Const(@{const_name Trueprop}, _)$concl) = rep_goal
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    86
                                                (#3(dest_state (st,i)));
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    87
*)
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    88
        val prems = Logic.strip_assums_hyp subgoal;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    89
        val concl = HOLogic.dest_Trueprop (Logic.strip_assums_concl subgoal);
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    90
        fun drot_tac k i = DETERM (rotate_tac k i);
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    91
        fun spec_tac 0 i = all_tac
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
    92
        |   spec_tac k i = EVERY' [dresolve_tac ctxt [spec], drot_tac ~1, spec_tac (k-1)] i;
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    93
        fun dup_spec_tac k i = if k = 0 then all_tac else EVERY'
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
    94
                      [DETERM o (eresolve_tac ctxt [all_dupE]), drot_tac ~2, spec_tac (k-1)] i;
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    95
        fun same_head _ (Const (x,_)) (Const (y,_)) = x = y
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    96
        |   same_head k (s$_)         (t$_)         = same_head k s t
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    97
        |   same_head k (Bound i)     (Bound j)     = i = j + k
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    98
        |   same_head _ _             _             = true;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
    99
        fun mapn f n []      = []
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   100
        |   mapn f n (x::xs) = f n x::mapn f (n+1) xs;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   101
        fun pres_tac (k,arrow,t) n i = drot_tac n i THEN (
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   102
          if same_head k t concl
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   103
          then dup_spec_tac k i THEN
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   104
               (if arrow then eresolve_tac ctxt [mp] i THEN drot_tac (~n) i else assume_tac ctxt i)
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   105
          else no_tac);
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   106
        val ptacs = mapn (fn n => fn t =>
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   107
                          pres_tac (ap (HOLogic.dest_Trueprop t)) n i) 0 prems;
46473
a687b75f9fa8 more conventional tactic setup;
wenzelm
parents: 46161
diff changeset
   108
  in Library.foldl (op APPEND) (no_tac, ptacs) end);
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   109
27229
f656a12e0f4e ptac/prolog_tac: proper context;
wenzelm
parents: 27153
diff changeset
   110
fun ptac ctxt prog = let
32952
aeb1e44fbc19 replaced String.concat by implode;
wenzelm
parents: 32740
diff changeset
   111
  val proga = maps (atomizeD ctxt) prog         (* atomize the prog *)
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   112
  in    (REPEAT_DETERM1 o FIRST' [
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   113
                resolve_tac ctxt [TrueI],                     (* "True" *)
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   114
                resolve_tac ctxt [conjI],                     (* "[| P; Q |] ==> P & Q" *)
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   115
                resolve_tac ctxt [allI],                      (* "(!!x. P x) ==> ! x. P x" *)
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   116
                resolve_tac ctxt [exI],                       (* "P x ==> ? x. P x" *)
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   117
                resolve_tac ctxt [impI] THEN'                 (* "(P ==> Q) ==> P --> Q" *)
52088
7d8b53e80ce7 proper run-time context;
wenzelm
parents: 52043
diff changeset
   118
                  asm_full_simp_tac (put_simpset atomize_ss ctxt) THEN'    (* atomize the asms *)
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   119
                  (REPEAT_DETERM o (eresolve_tac ctxt [conjE]))        (* split the asms *)
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   120
                ])
59498
50b60f501b05 proper context for resolve_tac, eresolve_tac, dresolve_tac, forward_tac etc.;
wenzelm
parents: 56467
diff changeset
   121
        ORELSE' resolve_tac ctxt [disjI1,disjI2]     (* "P ==> P | Q","Q ==> P | Q"*)
60754
02924903a6fd prefer tactics with explicit context;
wenzelm
parents: 59755
diff changeset
   122
        ORELSE' ((resolve_tac ctxt proga APPEND' hyp_resolve_tac ctxt)
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   123
                 THEN' (fn _ => check_HOHH_tac2))
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   124
end;
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   125
27229
f656a12e0f4e ptac/prolog_tac: proper context;
wenzelm
parents: 27153
diff changeset
   126
fun prolog_tac ctxt prog =
f656a12e0f4e ptac/prolog_tac: proper context;
wenzelm
parents: 27153
diff changeset
   127
  check_HOHH_tac1 THEN
f656a12e0f4e ptac/prolog_tac: proper context;
wenzelm
parents: 27153
diff changeset
   128
  DEPTH_SOLVE (ptac ctxt (map check_HOHH prog) 1);
21425
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   129
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   130
val prog_HOHH = [];
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   131
c11ab38b78a7 HOL-Prolog: converted legacy ML scripts;
wenzelm
parents:
diff changeset
   132
end;