The function IMP_RES_THEN is the basic building block for resolution
in HOL. This is not full higher-order, or even first-order,
resolution with unification, but simply one way simultaneous
pattern-matching (resulting in term and type instantiation) of the
antecedent of an implicative theorem to the conclusion of another
theorem (the candidate antecedent).
Given a theorem-tactic ttac and a theorem th, the theorem-tactical
IMP_RES_THEN uses RES_CANON to derive a canonical list of
implications from th, each of which has the form:
Ai |- !x1...xn. ui ==> vi
IMP_RES_THEN then produces a tactic that, when applied to
a goal A ?- g attempts to match each antecedent ui to each
assumption aj |- aj in the assumptions A. If the antecedent ui
of any implication matches the conclusion aj of any assumption, then
an instance of the theorem Ai u {aj} |- vi, called a ‘resolvent’,
is obtained by specialization of the variables x1, ..., xn and
type instantiation, followed by an application of modus ponens. There
may be more than one canonical implication and each implication is
tried against every assumption of the goal, so there may be several
resolvents (or, indeed, none).
Tactics are produced using the theorem-tactic ttac from all these
resolvents (failures of ttac at this stage are filtered out) and
these tactics are then applied in an unspecified sequence to the goal.
That is,
IMP_RES_THEN ttac th (A ?- g)
has the effect of:
MAP_EVERY (mapfilter ttac [... , (Ai u {aj} |- vi) , ...]) (A ?- g)
where the theorems Ai u {aj} |- vi are all the
consequences that can be drawn by a (single) matching modus-ponens
inference from the assumptions of the goal A ?- g and the
implications derived from the supplied theorem th. The sequence in
which the theorems Ai u {aj} |- vi are generated and the
corresponding tactics applied is unspecified.