Inductive logic programming is a subfield of symbolic artificial intelligence which uses logic programming as a uniform representation for examples, background knowledge and hypotheses. Given an encoding of the known background knowledge and a set of examples represented as a logical database of facts, an ILP system will derive a hypothesised logic program which entails all the positive and none of the negative examples.
The background knowledge is given as a logic theory, commonly in the form of Horn clauses used in logic programming. The positive and negative examples are given as a conjunction and of unnegated and negated groundliterals, respectively. A correct hypothesis is a logic proposition satisfying the following requirements. "Necessity" does not impose a restriction on, but forbids any generation of a hypothesis as long as the positive facts are explainable without it. "Sufficiency" requires any generated hypothesis to explain all positive examples. "Weak consistency" forbids generation of any hypothesis that contradicts the background knowledge. "Strong consistency" also forbids generation of any hypothesis that is inconsistent with the negative examples, given the background knowledge ; it implies "Weak consistency"; if no negative examples are given, both requirements coincide. Džeroski requires only "Sufficiency" and "Strong consistency".
Example
The following well-known example about learning definitions of family relations uses the abbreviations It starts from the background knowledge the positive examples and the trivial proposition to denote the absence of negative examples. Plotkin's "relative least general generalization " approach to inductive logic programming shall be used to obtain a suggestion about how to formally define the daughter relation. This approach uses the following steps.
Relativize each positive example literal with the complete background knowledge:
* from and, similar for all other background-knowledge literals
* from and, and many more negated literals
Delete all negated literals containing variables that don't occur in a positive literal:
*after deleting all negated literals containing other variables than, only remains, together with all ground literals from the background knowledge
Convert clauses back to Horn form:
*
The resulting Horn clause is the hypothesis obtained by the rlgg approach. Ignoring the background knowledge facts, the clause informally reads " is called a daughter of if is the parent of and is female", which is a commonly accepted definition. Concerning the [|above] requirements, "Necessity" was satisfied because the predicate doesn't appear in the background knowledge, which hence cannot imply any property containing this predicate, such as the positive examples are. "Sufficiency" is satisfied by the computed hypothesis, since it, together with from the background knowledge, implies the first positive example, and similarly and from the background knowledge implies the second positive example. "Weak consistency" is satisfied by, since holds in the Herbrand structure described by the background knowledge; similar for "Strong consistency". The common definition of the grandmother relation, viz., cannot be learned using the above approach, since the variable occurs in the clause body only; the corresponding literals would have been deleted in the 4th step of the approach. To overcome this flaw, that step has to be modified such that it can be parametrized with different literal post-selection heuristics. Historically, the GOLEM implementation is based on the rlgg approach.
Inductive Logic Programming system is a program that takes as an input logic theories and outputs a correct hypothesis wrt theories An algorithm of an ILP system consists of two parts: hypothesis search and hypothesis selection. First a hypothesis is searched with an inductive logic programming procedure, then a subset of the found hypotheses is chosen by a selection algorithm. A selection algorithm scores each of the found hypotheses and returns the ones with the highest score. An example of score function include minimal compression length where a hypothesis with a lowest Kolmogorov complexity has the highest score and is returned. An ILP system is complete iff for any input logic theories any correct hypothesis wrt to these input theories can be found with its hypothesis search procedure.
Hypothesis search
Modern ILP systems like Progol, Hail and Imparo find a hypothesis using the principle of the inverse entailment for theories,, :. First they construct an intermediate theory called a bridge theory satisfying the conditions and. Then as, they generalize the negation of the bridge theory with the anti-entailment. However, the operation of the anti-entailment since being highly non-deterministic is computationally more expensive. Therefore, an alternative hypothesis search can be conducted using the operation of the inverse subsumption instead which is less non-deterministic than anti-entailment. Questions of completeness of a hypothesis search procedure of specific ILP system arise. For example, Progol's hypothesis search procedure based on the inverse entailment inference rule is not complete by Yamamoto's example. On the other hand, Imparo is complete by both anti-entailment procedure and its extended inverse subsumption procedure.