TPTP Problem (.p)

Anthem produces TPTP problem files containing typed first-order formulas (TFF).

The Standard Preamble

The standard preamble (standard_interpretations.p) contains (problem-independent) types and axioms partially axiomatizing the conditions of standard interpretations.

Types

The type declarations define the sorts of the target (formula representation) language (the numeral type corresponds to vampire’s built-in integer type, $int):

    tff(general_type, type, general: $tType).
    tff(symbol_type, type, symbol: $tType).

Objects within the universe of a subsort must be mapped to an object within the supersort universe:

    tff(f__integer___decl, type, f__integer__: ($int) > general).
    tff(f__symbolic___decl, type, f__symbolic__: (symbol) > general).
    tff(p__is_integer__decl, type, p__is_integer__: (general) > $o).
    tff(p__is_symbolic__decl, type, p__is_symbolic__: (general) > $o).

#inf and #sup are special general terms which do not belong to the symbol or numeral subsorts:

    tff(inf_type, type, c__infimum__: general).
    tff(sup_type, type, c__supremum__: general).

General terms are ordered:

    tff(p__less_equal__decl, type, p__less_equal__: (general * general) > $o).
    tff(p__less__decl, type, p__less__: (general * general) > $o).
    tff(p__greater_equal__decl, type, p__greater_equal__: (general * general) > $o).
    tff(p__greater__decl, type, p__greater__: (general * general) > $o).

Axioms

    tff(p__is_integer__def_ax, axiom, ![X: general]: (p__is_integer__(X) <=> (?[N: $int]: (X = f__integer__(N))))).
    tff(p__is_symbolic__def_ax, axiom, ![X1: general]: (p__is_symbolic__(X1) <=> (?[X2: symbol]: (X1 = f__symbolic__(X2))))).

The universe of general terms consists of symbols, numerals, #inf, and #sup:

    tff(general_universe_ax, axiom, ![X: general]: ((X = c__infimum__) | p__is_integer__(X) | p__is_symbolic__(X) | (X = c__supremum__))).

The mappings from subsorts to supersorts should preserve equality between terms:

    tff(f__integer__def_ax, axiom, ![N1: $int, N2: $int]: ((f__integer__(N1) = f__integer__(N2)) <=> (N1 = N2))).
    tff(f__symbolic__def_ax, axiom, ![S1: symbol, S2: symbol]: ((f__symbolic__(S1) = f__symbolic__(S2)) <=> (S1 = S2))).

Numerals are ordered analogously to integers:

    tff(numeral_ordering_ax, axiom, ![N1: $int, N2: $int]: (p__less_equal__(f__integer__(N1), f__integer__(N2)) <=> $lesseq(N1, N2))).

The ordering is transitive:

    tff(transitive_ordering_ax, axiom, ![X1: general, X2: general, X3: general]: ((p__less_equal__(X1, X2) & p__less_equal__(X2, X3)) => p__less_equal__(X1, X3))).

The ordering is total:

    tff(antisymmetric_ordering_ax, axiom, ![X1: general, X2: general]: ((p__less_equal__(X1, X2) & p__less_equal__(X2, X1)) => (X1 = X2))).
    tff(strongly_connected_ordering_ax, axiom, ![X1: general, X2: general]: (p__less_equal__(X1, X2) | p__less_equal__(X2, X1))).

The remaining relations are defined in terms of less or equal:

    tff(p__less__def_ax, axiom, ![X1: general, X2: general]: (p__less__(X1, X2) <=> (p__less_equal__(X1, X2) & (X1 != X2)))).
    tff(p__greater_equal__def_ax, axiom, ![X1: general, X2: general]: (p__greater_equal__(X1, X2) <=> p__less_equal__(X2, X1))).
    tff(p__greater__def_ax, axiom, ![X1: general, X2: general]: (p__greater__(X1, X2) <=> (p__less_equal__(X2, X1) & (X1 != X2)))).

#inf is the minimum general term, numerals are less than symbols, and #sup is the maximum general term:

    tff(minimal_element_ax, axiom, ![N: $int]: p__less__(c__infimum__, f__integer__(N))).
    tff(numerals_less_than_symbols_ax, axiom, ![N: $int, S: symbol]: p__less__(f__integer__(N), f__symbolic__(S))).
    tff(maximal_element_ax, axiom, ![S: symbol]: p__less__(f__symbolic__(S), c__supremum__)).

Axioms Supporting External Equivalence

The standard preamble is part of every verification task. Additional axioms are added to this partial axiomatization based on the problem at hand.

Let P denote the set of problem types consisting of function constants for each placeholder in the user guide. Let F denote the set of symbolic constants (excluding placeholders) occurring anywhere in the problem. To ensure that each f in F satisfies the unique name assumption of Herbrand interpretations, we need a set of axioms O defining a total order on F. For instance, if F is {a, b, c}, then O is {a < b, b < c}. Note that a < c is a consequence of the transitivity axiom of the preamble. Additionally, we need a type declaration for every predicate in the problem (denote this set of declarations as R). We extend the standard preamble with \(P \cup F \cup O \cup R\). For example, for a problem containing an integer placeholder k$, symbolic constants a and c, and predicates p/2 and q/1, we add the axioms

    tff(type, type, k$i: $int).
    tff(type, type, a: symbol).
    tff(type, type, c: symbol).
    tff(symbolic_constant_order, axiom, p__less__(f__symbolic__(a), f__symbolic__(c))).
    tff(predicate_0, type, p: (general * general) > $o).
    tff(predicate_1, type, q: (general) > $o).

Axioms Supporting Strong Equivalence

Since strong equivalence does not support user guides or placeholders, the standard preamble is extended with \(F \cup O \cup R\) instead. Additionally, we need axioms representing the ordering between the here and there worlds. Thus, for a pair of predicates (hp, tp) we add the axiom \[\widetilde{\forall} (hp \rightarrow tp) \]