/usr/share/hol88-2.02.19940316/contrib/auxiliary/tactics.ml is in hol88-contrib-source 2.02.19940316-14.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 | letrec sublist numl l =
if null numl then []
else (el (hd numl) l).(sublist (tl numl) l);;
let SUB_ASSUM_TAC filter:tactic (asl,g) =
let goal = (sublist filter asl,g) in
let prf = \[thm].TAC_PROOF((asl,g),ACCEPT_TAC thm) in
[goal],prf;;
let FILTER_ASSUM_TAC filter termtactic (asl,g) =
let tmlist = sublist filter asl in
(MAP_EVERY termtactic tmlist) (asl,g);;
let FILTER_RULE_ASSUM_TAC filter rule (asl,g) =
letrec mklist n =(if n=0 then []
else (mklist (n-1))@[n]) in
let intlist = mklist (length asl) in
let tasl = map ASSUME asl in
let fasl = (map (\n. if (mem n filter) then rule (el n tasl)
else (el n tasl)) intlist) in
MAP_EVERY ASSUME_TAC (rev fasl) ([],g);;
let REWRITE_RULE_ASSUM_TAC filter1 filter2 =
ASSUM_LIST(\asl.FILTER_RULE_ASSUM_TAC filter1 (REWRITE_RULE (sublist filter2 asl)));;
let EXP_UNIQUE_TAC =
REWRITE_TAC[EXISTS_UNIQUE_DEF] THEN
CONV_TAC (REDEPTH_CONV BETA_CONV);;
let FILTER_FILTER_RULE_ASSUM_TAC filter1 filter2 rule =
ASSUM_LIST(\asl.FILTER_RULE_ASSUM_TAC filter1
(rule (sublist filter2 asl)));;
let DEFINE deftm =
let y,fx = dest_eq deftm in
let name,ty = dest_var y in
let thm = EXISTS("? ^y.^deftm",fx) (REFL fx) in
let prf = \[th].(CHOOSE(y,thm) th) in
\(asl,g).
([deftm.asl,g],prf)
;;
ml_curried_infix `TIMES`;;
letrec n TIMES tac =
if n=0 then ALL_TAC
if n =1 then tac
else tac THEN ((n-1) TIMES tac);;
let FILTER_STRIP_ASSUM_TAC nl =
let l = length nl in
FILTER_ASSUM_TAC (rev nl) UNDISCH_TAC THEN
(l TIMES STRIP_TAC) ;;
let GENVAR th =
let vl = fst(strip_forall (concl th)) in
let vln = map (genvar o type_of) vl in
GEN_ALL (SPECL vln th);;
% --------------------------------------------------------------------- %
% HOL_PART_MATCH and HOL_MATCH_MP now deleted from system. %
% But added here in order to make this library file compile. %
% Library needs to be rewritten (and documented!) [TFM 90.04.27] %
% --------------------------------------------------------------------- %
let HOL_PART_MATCH partfn th =
let pth = SPEC_ALL (GEN_ALL th) in
let pat = partfn(concl pth) in
let matchfn = match pat in
\tm. INST_TY_TERM (matchfn tm) pth;;
let HOL_MATCH_MP impth =
let match = HOL_PART_MATCH (fst o dest_imp) impth
? failwith `HOL_MATCH_MP`
in
\th. MP (match (concl th)) th;;
% --------------------------------------------------------------------- %
% HOL_STRIP_ASSUME_TAC added too, for the same reason. %
% Library needs to be rewritten (and documented!) [TFM 90.04.27] %
% --------------------------------------------------------------------- %
let HOL_STRIP_THM_THEN =
FIRST_TCL [CONJUNCTS_THEN; DISJ_CASES_THEN];;
let HOL_STRIP_ASSUME_TAC =
(REPEAT_TCL HOL_STRIP_THM_THEN) CHECK_ASSUME_TAC;;
% --------------------------------------------------------------------- %
% QUESTION: %
% what does the following stuff do that the new (version 1.12) %
% resolution tools can't handle? [TFM 90.04.27] %
% --------------------------------------------------------------------- %
letrec NEW_HOL_RESOLVE_THEN antel ttac impth : tactic =
let answers = map GEN_ALL (mapfilter (HOL_MATCH_MP impth) antel) in
EVERY (mapfilter ttac answers)
THEN
(EVERY (mapfilter (NEW_HOL_RESOLVE_THEN antel ttac) answers));;
let NEW_IMP_RES_THEN ttac impth =
ASSUM_LIST
(\asl. EVERY (mapfilter (NEW_HOL_RESOLVE_THEN asl ttac) (RES_CANON (GENVAR impth))));;
let NEW_RES_THEN ttac =
ASSUM_LIST (EVERY o (mapfilter (NEW_IMP_RES_THEN ttac)));;
let NEW_IMP_RES_TAC = NEW_IMP_RES_THEN HOL_STRIP_ASSUME_TAC
and NEW_RES_TAC = NEW_RES_THEN HOL_STRIP_ASSUME_TAC;;
let FILTER_ASSUM_LIST filter asltac =
ASSUM_LIST (asltac o (sublist filter));;
|