"Predicate logic" redirects here.
For logics admitting predicate or function variables, see Higher-order logic.
First-order logic—also known as predicate logic, quantificational logic, and first-order predicate calculus—is a collection of formal systems used in mathematics, philosophy, linguistics, and computer science.
First-order logic uses quantified variables over non-logical objects, and allows the use of sentences that contain variables, so that rather than propositions such as "Socrates is a man", one can have expressions in the form "there exists x such that x is Socrates and x is a man", where "there exists" is a quantifier, while x is a variable.
A theory about a topic is usually a first-order logic together with a specified domain of discourse (over which the quantified variables range), finitely many functions from that domain to itself, finitely many predicates defined on that domain, and a set of axioms believed to hold about them.
Sometimes, "theory" is understood in a more formal sense, which is just a set of sentences in first-order logic.
The adjective "first-order" distinguishes first-order logic from higher-order logic, in which there are predicates having predicates or functions as arguments, or in which one or both of predicate quantifiers or function quantifiers are permitted.
In first-order theories, predicates are often associated with sets.
In interpreted higher-order theories, predicates may be interpreted as sets of sets.
There are many deductive systems for first-order logic which are both sound (i.e., all provable statements are true in all models) and complete (i.e. all statements which are true in all models are provable).
For a history of first-order logic and how it came to dominate formal logic, see José Ferreirós (2001).
Consider the two sentences "Socrates is a philosopher" and "Plato is a philosopher".
In propositional logic, these sentences are viewed as being unrelated, and might be denoted, for example, by variables such as p and q.
The predicate "is a philosopher" occurs in both sentences, which have a common structure of "a is a philosopher".
The variable a is instantiated as "Socrates" in the first sentence, and is instantiated as "Plato" in the second sentence.
While first-order logic allows for the use of predicates, such as "is a philosopher" in this example, propositional logic does not.
Relationships between predicates can be stated using logical connectives.
Consider, for example, the first-order formula "if a is a philosopher, then a is a scholar".
This formula is a conditional statement with "a is a philosopher" as its hypothesis, and "a is a scholar" as its conclusion.
The truth of this formula depends on which object is denoted by a, and on the interpretations of the predicates "is a philosopher" and "is a scholar".
Quantifiers can be applied to variables in a formula.
The variable a in the previous formula can be universally quantified, for instance, with the first-order sentence "For every a, if a is a philosopher, then a is a scholar".
The universal quantifier "for every" in this sentence expresses the idea that the claim "if a is a philosopher, then a is a scholar" holds for all choices of a.
The negation of the sentence "For every a, if a is a philosopher, then a is a scholar" is logically equivalent to the sentence "There exists a such that a is a philosopher and a is not a scholar".
The existential quantifier "there exists" expresses the idea that the claim "a is a philosopher and a is not a scholar" holds for some choice of a.
The predicates "is a philosopher" and "is a scholar" each take a single variable.
In general, predicates can take several variables.
In the first-order sentence "Socrates is the teacher of Plato", the predicate "is the teacher of" takes two variables.
An interpretation (or model) of a first-order formula specifies what each predicate means, and the entities that can instantiate the variables.
These entities form the domain of discourse or universe, which is usually required to be a nonempty set.
For example, in an interpretation with the domain of discourse consisting of all human beings and the predicate "is a philosopher" understood as "was the author of the Republic", the sentence "There exists a such that a is a philosopher" is seen as being true, as witnessed by Plato.
There are two key parts of first-order logic.
See also: Alphabet (formal languages)
Unlike natural languages, such as English, the language of first-order logic is completely formal, so that it can be mechanically determined whether a given expression is well formed.
There are two key types of well-formed expressions: terms, which intuitively represent objects, and formulas, which intuitively express predicates that can be true or false.
The terms and formulas of first-order logic are strings of symbols, where all the symbols together form the alphabet of the language.
As with all formal languages, the nature of the symbols themselves is outside the scope of formal logic; they are often regarded simply as letters and punctuation symbols.
There are several logical symbols in the alphabet, which vary by author but usually include:
- The quantifier symbols: ∀ for universal quantification, and ∃ for existential quantification
- The logical connectives: ∧ for conjunction, ∨ for disjunction, → for implication, ↔ for biconditional, ¬ for negation. Occasionally other logical connective symbols are included. Some authors use Cpq, instead of →, and Epq, instead of ↔, especially in contexts where → is used for other purposes. Moreover, the horseshoe ⊃ may replace →; the triple-bar ≡ may replace ↔; a tilde (~), Np, or Fp, may replace ¬; a double bar ||, + or Apq may replace ∨; and ampersand &, Kpq, or the middle dot, ⋅, may replace ∧, especially if these symbols are not available for technical reasons. (The aforementioned symbols Cpq, Epq, Np, Apq, and Kpq are used in Polish notation.)
- Parentheses, brackets, and other punctuation symbols. The choice of such symbols varies depending on context.
- An infinite set of variables, often denoted by lowercase letters at the end of the alphabet x, y, z, ... . Subscripts are often used to distinguish variables: x0, x1, x2, ... .
- An equality symbol (sometimes, identity symbol) =; see the section on equality below.
Not all of these symbols are required–only one of the quantifiers, negation and conjunction, variables, brackets and equality suffice.
There are numerous minor variations that may define additional logical symbols:
- In some occasions, the truth constants T, Vpq, or ⊤, for "true" and F, Opq, or ⊥, for "false" are included. Without any such logical operators of valence 0, these two constants can only be expressed using quantifiers.
- In other occasions, additional logical connectives are included, such as the Sheffer stroke, Dpq (NAND), and exclusive or, Jpq.
The non-logical symbols represent predicates (relations), functions and constants on the domain of discourse.
It used to be standard practice to use a fixed, infinite set of non-logical symbols for all purposes.
A more recent practice is to use different non-logical symbols according to the application one has in mind.
Therefore, it has become necessary to name the set of all non-logical symbols used in a particular application.
This choice is made via a signature.
The traditional approach is to have only one, infinite, set of non-logical symbols (one signature) for all applications.
Consequently, under the traditional approach there is only one language of first-order logic.
This approach is still common, especially in philosophically oriented books.
- For every integer n ≥ 0, there is a collection of n-ary, or n-place, predicate symbols. Because they represent relations between n elements, they are also called relation symbols. For each arity n, we have an infinite supply of them:
- P0, P1, P2, P3, ...
- f0, f1, f2, f3, ...
In contemporary mathematical logic, the signature varies by application.
There are no restrictions on the number of non-logical symbols.
Uncountable signatures occur for example in modern proofs of the Löwenheim–Skolem theorem.
In this approach, every non-logical symbol is of one of the following types.
- A predicate symbol (or relation symbol) with some valence (or arity, number of arguments) greater than or equal to 0. These are often denoted by uppercase letters such as P, Q and R.
- Relations of valence 0 can be identified with propositional variables. For example, P, which can stand for any statement.
- For example, P(x) is a predicate variable of valence 1. One possible interpretation is "x is a man".
- Q(x,y) is a predicate variable of valence 2. Possible interpretations include "x is greater than y" and "x is the father of y".
- Examples: f(x) may be interpreted as for "the father of x". In arithmetic, it may stand for "-x". In set theory, it may stand for "the power set of x". In arithmetic, g(x,y) may stand for "x+y". In set theory, it may stand for "the union of x and y".
- Function symbols of valence 0 are called constant symbols, and are often denoted by lowercase letters at the beginning of the alphabet such as a, b and c. The symbol a may stand for Socrates. In arithmetic, it may stand for 0. In set theory, such a constant may stand for the empty set.
The traditional approach can be recovered in the modern approach, by simply specifying the "custom" signature to consist of the traditional sequences of non-logical symbols.
|<index> ::= ""||<index> "'"
<variable> ::= "x" <index> <constant> ::= "c" <index> <unary function> ::= "f1" <index> <binary function> ::= "f2" <index> <ternary function> ::= "f3" <index> <unary predicate> ::= "p1" <index> <binary predicate> ::= "p2" <index> <ternary predicate> ::= "p3" <index> <term> ::= <variable>
|<constant>||<unary function> "(" <term> ")"||<binary function> "(" <term> "," <term> ")"||<ternary function> "(" <term> "," <term> "," <term> ")"
<atomic formula> ::= "TRUE"
|"FALSE"||<term> "=" <term>||<unary predicate> "(" <term> ")"||<binary predicate> "(" <term> "," <term> ")"||<ternary predicate> "(" <term> "," <term> "," <term> ")"
<formula> ::= <atomic formula>
|"¬" <formula>||<formula> "∧" <formula>||<formula> "∨" <formula>||<formula> "⇒" <formula>||<formula> "⇔" <formula>||"(" <formula> ")"||"∀" <variable> <formula>||"∃" <variable> <formula>|
|The above context-free grammar in Backus-Naur form defines the language of syntactically valid first-order formulas with function symbols and predicate symbols up to arity 3. For higher arities, it needs to be adapted accordingly.|
|The example formula ∀x ∃x' (¬x=c) ⇒ f2(x,x')=c' describes multiplicative inverses when f2', c, and c' are interpreted as multiplication, zero, and one, respectively.|
The formation rules define the terms and formulas of first-order logic.
When terms and formulas are represented as strings of symbols, these rules can be used to write a formal grammar for terms and formulas.
These rules are generally context-free (each production has a single symbol on the left side), except that the set of symbols may be allowed to be infinite and there may be many start symbols, for example the variables in the case of terms.
- Variables. Any variable is a term.
- Functions. Any expression f(t1,...,tn) of n arguments (where each argument ti is a term and f is a function symbol of valence n) is a term. In particular, symbols denoting individual constants are nullary function symbols, and thus are terms.
Only expressions which can be obtained by finitely many applications of rules 1 and 2 are terms.
For example, no expression involving a predicate symbol is a term.
Only expressions which can be obtained by finitely many applications of rules 1–5 are formulas.
The formulas obtained from the first two rules are said to be atomic formulas.
The role of the parentheses in the definition is to ensure that any formula can only be obtained in one way—by following the inductive definition (i.e., there is a unique parse tree for each formula).
This property is known as unique readability of formulas.
There are many conventions for where parentheses are used in formulas.
For example, some authors use colons or full stops instead of parentheses, or change the places in which parentheses are inserted.
Each author's particular definition must be accompanied by a proof of unique readability.
This definition of a formula does not support defining an if-then-else function ite(c, a, b), where "c" is a condition expressed as a formula, that would return "a" if c is true, and "b" if it is false.
This is because both predicates and functions can only accept terms as parameters, but the first parameter is a formula.
Some languages built on first-order logic, such as SMT-LIB 2.0, add this.
For convenience, conventions have been developed about the precedence of the logical operators, to avoid the need to write parentheses in some cases.
These rules are similar to the order of operations in arithmetic.
A common convention is:
Moreover, extra punctuation not required by the definition may be inserted—to make formulas easier to read.
Thus the formula
might be written as
In some fields, it is common to use infix notation for binary relations and functions, instead of the prefix notation defined above.
For example, in arithmetic, one typically writes "2 + 2 = 4" instead of "=(+(2,2),4)".
It is common to regard formulas in infix notation as abbreviations for the corresponding formulas in prefix notation, cf.
becomes "∀x∀y→Pfx¬→ PxQfyxz".
Free and bound variables
Main article: Free variables and bound variables
In a formula, a variable may occur free or bound (or both).
Intuitively, a variable occurrence is free in a formula if it is not quantified: in ∀y P(x, y), the sole occurrence of variable x is free while that of y is bound.
The free and bound variable occurrences in a formula are defined inductively as follows.
- Atomic formulas. If φ is an atomic formula, then x occurs free in φ if and only if x occurs in φ. Moreover, there are no bound variables in any atomic formula.
- Negation. x occurs free in ¬φ if and only if x occurs free in φ. x occurs bound in ¬φ if and only if x occurs bound in φ.
- Binary connectives. x occurs free in (φ → ψ) if and only if x occurs free in either φ or ψ. x occurs bound in (φ → ψ) if and only if x occurs bound in either φ or ψ. The same rule applies to any other binary connective in place of →.
- Quantifiers. x occurs free in ∀y φ, if and only if x occurs free in φ and x is a different symbol from y. Also, x occurs bound in ∀y φ, if and only if x is y or x occurs bound in φ. The same rule holds with ∃ in place of ∀.
For example, in ∀x ∀y (P(x) → Q(x,f(x),z)), x and y occur only bound, z occurs only free, and w is neither because it does not occur in the formula.
Free and bound variables of a formula need not be disjoint sets: in the formula P(x) → ∀x Q(x), the first occurrence of x, as argument of P, is free while the second one, as argument of Q, is bound.
A formula in first-order logic with no free variable occurrences is called a first-order sentence.
These are the formulas that will have well-defined truth values under an interpretation.
For example, whether a formula such as Phil(x) is true must depend on what x represents.
But the sentence ∃x Phil(x) will be either true or false in a given interpretation.
Example: ordered abelian groups
In mathematics, the language of ordered abelian groups has one constant symbol 0, one unary function symbol −, one binary function symbol +, and one binary relation symbol ≤.
An interpretation of a first-order language assigns a denotation to each non-logical symbol in that language.
It also determines a domain of discourse that specifies the range of the quantifiers.
The result is that each term is assigned an object that it represents, each predicate is assigned a property of objects, and each sentence is assigned a truth value.
In this way, an interpretation provides semantic meaning to the terms, the predicates, and formulas of the language.
The study of the interpretations of formal languages is called formal semantics.
What follows is a description of the standard or Tarskian semantics for first-order logic.
(It is also possible to define game semantics for first-order logic, but aside from requiring the axiom of choice, game semantics agree with Tarskian semantics for first-order logic, so game semantics will not be elaborated herein.)
The interpretation of a function symbol is a function.
For example, if the domain of discourse consists of integers, a function symbol f of arity 2 can be interpreted as the function that gives the sum of its arguments.
In other words, the symbol f is associated with the function I(f) which, in this interpretation, is addition.
The interpretation of an n-ary predicate symbol is a set of n-tuples of elements of the domain of discourse.
This means that, given an interpretation, a predicate symbol, and n elements of the domain of discourse, one can tell whether the predicate is true of those elements according to the given interpretation.
For example, an interpretation I(P) of a binary predicate symbol P may be the set of pairs of integers such that the first one is less than the second.
According to this interpretation, the predicate P would be true if its first argument is less than the second.
Main article: Structure (mathematical logic)
The most common way of specifying an interpretation (especially in mathematics) is to specify a structure (also called a model; see below).
The structure consists of a nonempty set D that forms the domain of discourse and an interpretation I of the non-logical terms of the signature.
This interpretation is itself a function:
Evaluation of truth values
First, the variable assignment μ can be extended to all terms of the language, with the result that each term maps to a single element of the domain of discourse.
The following rules are used to make this assignment:
Next, each formula is assigned a truth value.
The inductive definition used to make this assignment is called the T-schema.
There is a second common approach to defining truth values that does not rely on variable assignment functions.
Instead, given an interpretation M, one first adds to the signature a collection of constant symbols, one for each element of the domain of discourse in M; say that for each d in the domain the constant symbol cd is fixed.
The interpretation is extended so that each new constant symbol is assigned to its corresponding element of the domain.
One now defines truth for quantified formulas syntactically, as follows:
This alternate approach gives exactly the same truth values to all sentences as the approach via variable assignments.
Validity, satisfiability, and logical consequence
See also: Satisfiability
Satisfiability of formulas with free variables is more complicated, because an interpretation on its own does not determine the truth value of such a formula.
The most common convention is that a formula with free variables is said to be satisfied by an interpretation if the formula remains true regardless which individuals from the domain of discourse are assigned to its free variables.
This has the same effect as saying that a formula is satisfied if and only if its universal closure is satisfied.
A formula is logically valid (or simply valid) if it is true in every interpretation.
These formulas play a role similar to tautologies in propositional logic.
A formula φ is a logical consequence of a formula ψ if every interpretation that makes ψ true also makes φ true.
In this case one says that φ is logically implied by ψ.
An alternate approach to the semantics of first-order logic proceeds via abstract algebra.
This approach generalizes the Lindenbaum–Tarski algebras of propositional logic.
There are three ways of eliminating quantified variables from first-order logic that do not involve replacing quantifiers with other variable binding term operators:
- Cylindric algebra, by Alfred Tarski and colleagues;
- Polyadic algebra, by Paul Halmos;
- Predicate functor logic, mainly due to Willard Quine.
First-order theories, models, and elementary classes
A first-order theory of a particular signature is a set of axioms, which are sentences consisting of symbols from that signature.
The set of axioms is often finite or recursively enumerable, in which case the theory is called effective.
Some authors require theories to also include all logical consequences of the axioms.
The axioms are considered to hold within the theory and from them other sentences that hold within the theory can be derived.
A first-order structure that satisfies all sentences in a given theory is said to be a model of the theory.
An elementary class is the set of all structures satisfying a particular theory.
These classes are a main subject of study in model theory.
Many theories have an intended interpretation, a certain model that is kept in mind when studying the theory.
However, the Löwenheim–Skolem theorem shows that most first-order theories will also have other, nonstandard models.
A theory is consistent if it is not possible to prove a contradiction from the axioms of the theory.
A theory is complete if, for every formula in its signature, either that formula or its negation is a logical consequence of the axioms of the theory.
Gödel's incompleteness theorem shows that effective first-order theories that include a sufficient portion of the theory of the natural numbers can never be both consistent and complete.
Main article: Empty domain
The definition above requires that the domain of discourse of any interpretation must be nonempty.
There are settings, such as inclusive logic, where empty domains are permitted.
Moreover, if a class of algebraic structures includes an empty structure (for example, there is an empty poset), that class can only be an elementary class in first-order logic if empty domains are permitted or the empty structure is removed from the class.
There are several difficulties with empty domains, however:
Thus, when the empty domain is permitted, it must often be treated as a special case.
Most authors, however, simply exclude the empty domain by definition.
A deductive system is used to demonstrate, on a purely syntactic basis, that one formula is a logical consequence of another formula.
These share the common property that a deduction is a finite syntactic object; the format of this object, and the way it is constructed, vary widely.
These finite deductions themselves are often called derivations in proof theory.
They are also often called proofs, but are completely formalized unlike natural-language mathematical proofs.
A deductive system is sound if any formula that can be derived in the system is logically valid.
Conversely, a deductive system is complete if every logically valid formula is derivable.
All of the systems discussed in this article are both sound and complete.
They also share the property that it is possible to effectively verify that a purportedly valid deduction is actually a deduction; such deduction systems are called effective.
A key property of deductive systems is that they are purely syntactic, so that derivations can be verified without considering any interpretation.
Thus a sound argument is correct in every possible interpretation of the language, regardless whether that interpretation is about mathematics, economics, or some other area.
In general, logical consequence in first-order logic is only semidecidable: if a sentence A logically implies a sentence B then this can be discovered (for example, by searching for a proof until one is found, using some effective, sound, complete proof system).
However, if A does not logically imply B, this does not mean that A logically implies the negation of B.
There is no effective procedure that, given formulas A and B, always correctly decides whether A logically implies B.
Rules of inference
Further information: List of rules of inference
A rule of inference states that, given a particular formula (or set of formulas) with a certain property as a hypothesis, another specific formula (or set of formulas) can be derived as a conclusion.
The rule is sound (or truth-preserving) if it preserves validity in the sense that whenever any interpretation satisfies the hypothesis, that interpretation also satisfies the conclusion.
For example, one common rule of inference is the rule of substitution.
If t is a term and φ is a formula possibly containing the variable x, then φ[t/x] is the result of replacing all free instances of x by t in φ.
The substitution rule states that for any φ and any term t, one can conclude φ[t/x] from φ provided that no free variable of t becomes bound during the substitution process.
(If some free variable of t becomes bound, then to substitute t for x it is first necessary to change the bound variables of φ to differ from the free variables of t.)
The substitution rule demonstrates several common aspects of rules of inference.
It is entirely syntactical; one can tell whether it was correctly applied without appeal to any interpretation.
It has (syntactically defined) limitations on when it can be applied, which must be respected to preserve the correctness of derivations.
Moreover, as is often the case, these limitations are necessary because of interactions between free and bound variables that occur during syntactic manipulations of the formulas involved in the inference rule.
Hilbert-style systems and natural deduction
A deduction in a Hilbert-style deductive system is a list of formulas, each of which is a logical axiom, a hypothesis that has been assumed for the derivation at hand, or follows from previous formulas via a rule of inference.
The logical axioms consist of several axiom schemas of logically valid formulas; these encompass a significant amount of propositional logic.
The rules of inference enable the manipulation of quantifiers.
Typical Hilbert-style systems have a small number of rules of inference, along with several infinite schemas of logical axioms.
Natural deduction systems resemble Hilbert-style systems in that a deduction is a finite list of formulas.
However, natural deduction systems have no logical axioms; they compensate by adding additional rules of inference that can be used to manipulate the logical connectives in formulas in the proof.
Further information: Sequent calculus
The sequent calculus was developed to study the properties of natural deduction systems.
Instead of working with one formula at a time, it uses sequents, which are expressions of the form
Further information: Method of analytic tableaux
As with the tableaux method, a formula is proved by showing that the negation of the formula is unsatisfiable.
Resolution is commonly used in automated theorem proving.
Many identities can be proved, which establish equivalences between particular formulas.
These identities allow for rearranging formulas by moving quantifiers across other connectives, and are useful for putting formulas in prenex normal form.
Some provable identities include:
Equality and its axioms
There are several different conventions for using equality (or identity) in first-order logic.
The most common convention, known as first-order logic with equality, includes the equality symbol as a primitive logical symbol which is always interpreted as the real equality relation between members of the domain of discourse, such that the "two" given members are the same member.
This approach also adds certain axioms about equality to the deductive system employed.
These equality axioms are:
- Reflexivity. For each variable x, x = x.
- Substitution for functions. For all variables x and y, and any function symbol f,
- x = y → f(...,x,...) = f(...,y,...).
- x = y → (φ → φ').
These are axiom schemas, each of which specifies an infinite set of axioms.
The third schema is known as Leibniz's law, "the principle of substitutivity", "the indiscernibility of identicals", or "the replacement property".
The second schema, involving the function symbol f, is (equivalent to) a special case of the third schema, using the formula
- x = y → (f(...,x,...) = z → f(...,y,...) = z).
Many other properties of equality are consequences of the axioms above, for example:
- Symmetry. If x = y then y = x.
- Transitivity. If x = y and y = z then x = z.
First-order logic without equality
An alternate approach considers the equality relation to be a non-logical symbol.
This convention is known as first-order logic without equality.
If an equality relation is included in the signature, the axioms of equality must now be added to the theories under consideration, if desired, instead of being considered rules of logic.
The main difference between this method and first-order logic with equality is that an interpretation may now interpret two distinct individuals as "equal" (although, by Leibniz's law, these will satisfy exactly the same formulas under any interpretation).
That is, the equality relation may now be interpreted by an arbitrary equivalence relation on the domain of discourse that is congruent with respect to the functions and relations of the interpretation.
When this second convention is followed, the term normal model is used to refer to an interpretation where no distinct individuals a and b satisfy a = b.
In first-order logic with equality, only normal models are considered, and so there is no term for a model other than a normal model.
When first-order logic without equality is studied, it is necessary to amend the statements of results such as the Löwenheim–Skolem theorem so that only normal models are considered.
First-order logic without equality is often employed in the context of second-order arithmetic and other higher-order theories of arithmetic, where the equality relation between sets of natural numbers is usually omitted.
Defining equality within a theory
If a theory has a binary formula A(x,y) which satisfies reflexivity and Leibniz's law, the theory is said to have equality, or to be a theory with equality.
The theory may not have all instances of the above schemas as axioms, but rather as derivable theorems.
For example, in theories with no function symbols and a finite number of relations, it is possible to define equality in terms of the relations, by defining the two terms s and t to be equal if any relation is unchanged by changing s to t in any argument.
Some theories allow other ad hoc definitions of equality:
These results concern general properties of first-order logic itself, rather than properties of individual theories.
They provide fundamental tools for the construction of models of first-order theories.
Completeness and undecidability
Gödel's completeness theorem, proved by Kurt Gödel in 1929, establishes that there are sound, complete, effective deductive systems for first-order logic, and thus the first-order logical consequence relation is captured by finite provability.
Naively, the statement that a formula φ logically implies a formula ψ depends on every model of φ; these models will in general be of arbitrarily large cardinality, and so logical consequence cannot be effectively verified by checking every model.
However, it is possible to enumerate all finite derivations and search for a derivation of ψ from φ.
If ψ is logically implied by φ, such a derivation will eventually be found.
Thus first-order logical consequence is semidecidable: it is possible to make an effective enumeration of all pairs of sentences (φ,ψ) such that ψ is a logical consequence of φ.
This means that there is no decision procedure that determines whether arbitrary formulas are logically valid.
This result was established independently by Alonzo Church and Alan Turing in 1936 and 1937, respectively, giving a negative answer to the Entscheidungsproblem posed by David Hilbert and Wilhelm Ackermann in 1928.
Their proofs demonstrate a connection between the unsolvability of the decision problem for first-order logic and the unsolvability of the halting problem.
There are systems weaker than full first-order logic for which the logical consequence relation is decidable.
These include propositional logic and monadic predicate logic, which is first-order logic restricted to unary predicate symbols and no function symbols.
The Bernays–Schönfinkel class of first-order formulas is also decidable.
Decidable subsets of first-order logic are also studied in the framework of description logics.
The Löwenheim–Skolem theorem
That is, there is no first-order formula φ(x) such that an arbitrary structure M satisfies φ if and only if the domain of discourse of M is countable (or, in the second case, uncountable).
The Löwenheim–Skolem theorem implies that infinite structures cannot be categorically axiomatized in first-order logic.
For example, there is no first-order theory whose only model is the real line: any first-order theory with an infinite model also has a model of cardinality larger than the continuum.
Since the real line is infinite, any theory satisfied by the real line is also satisfied by some nonstandard models.
When the Löwenheim–Skolem theorem is applied to first-order set theories, the nonintuitive consequences are known as Skolem's paradox.
The compactness theorem
The compactness theorem states that a set of first-order sentences has a model if and only if every finite subset of it has a model.
This implies that if a formula is a logical consequence of an infinite set of first-order axioms, then it is a logical consequence of some finite number of those axioms.
This theorem was proved first by Kurt Gödel as a consequence of the completeness theorem, but many additional proofs have been obtained over time.
It is a central tool in model theory, providing a fundamental method for constructing models.
The compactness theorem has a limiting effect on which collections of first-order structures are elementary classes.
For example, the compactness theorem implies that any theory that has arbitrarily large finite models has an infinite model.
Thus the class of all finite graphs is not an elementary class (the same holds for many other algebraic structures).
Main article: Lindström's theorem
Per Lindström showed that the metalogical properties just discussed actually characterize first-order logic in the sense that no stronger logic can also have those properties (Ebbinghaus and Flum 1994, Chapter XIII).
Lindström defined a class of abstract logical systems, and a rigorous definition of the relative strength of a member of this class.
He established two theorems for systems of this type:
- A logical system satisfying Lindström's definition that contains first-order logic and satisfies both the Löwenheim–Skolem theorem and the compactness theorem must be equivalent to first-order logic.
- A logical system satisfying Lindström's definition that has a semidecidable logical consequence relation and satisfies the Löwenheim–Skolem theorem must be equivalent to first-order logic.
Although first-order logic is sufficient for formalizing much of mathematics, and is commonly used in computer science and other fields, it has certain limitations.
These include limitations on its expressiveness and limitations of the fragments of natural languages that it can describe.
The Löwenheim–Skolem theorem shows that if a first-order theory has any infinite model, then it has infinite models of every cardinality.
In particular, no first-order theory with an infinite model can be categorical.
Thus there is no first-order theory whose only model has the set of natural numbers as its domain, or whose only model has the set of real numbers as its domain.
Many extensions of first-order logic, including infinitary logics and higher-order logics, are more expressive in the sense that they do permit categorical axiomatizations of the natural numbers or real numbers.
This expressiveness comes at a metalogical cost, however: by Lindström's theorem, the compactness theorem and the downward Löwenheim–Skolem theorem cannot hold in any logic stronger than first-order.
Formalizing natural languages
First-order logic is able to formalize many simple quantifier constructions in natural language, such as "every person who lives in Perth lives in Australia".
But there are many more complicated features of natural language that cannot be expressed in (single-sorted) first-order logic.
"Any logical system which is appropriate as an instrument for the analysis of natural language needs a much richer structure than first-order predicate logic".
|Quantification over properties||If John is self-satisfied, then there is at least one thing he has in common with Peter.||Example requires a quantifier over predicates, which cannot be implemented in single-sorted first-order logic: Zj→ ∃X(Xj∧Xp).|
|Quantification over properties||Santa Claus has all the attributes of a sadist.||Example requires quantifiers over predicates, which cannot be implemented in single-sorted first-order logic: ∀X(∀x(Sx → Xx)→Xs).|
|Predicate adverbial||John is walking quickly.||Example cannot be analysed as Wj ∧ Qj; predicate adverbials are not the same kind of thing as second-order predicates such as colour.|
|Relative adjective||Jumbo is a small elephant.||Example cannot be analysed as Sj ∧ Ej; predicate adjectives are not the same kind of thing as second-order predicates such as colour.|
|Predicate adverbial modifier||John is walking very quickly.||-|
|Relative adjective modifier||Jumbo is terribly small.||An expression such as "terribly", when applied to a relative adjective such as "small", results in a new composite relative adjective "terribly small".|
|Prepositions||Mary is sitting next to John.||The preposition "next to" when applied to "John" results in the predicate adverbial "next to John".|
Restrictions, extensions, and variations
There are many variations of first-order logic.
Some of these are inessential in the sense that they merely change notation without affecting the semantics.
Others change the expressive power more significantly, by extending the semantics through additional quantifiers or other new logical symbols.
For example, infinitary logics permit formulas of infinite size, and modal logics add symbols for possibility and necessity.
First-order logic can be studied in languages with fewer logical symbols than were described above.
Restrictions such as these are useful as a technique to reduce the number of inference rules or axiom schemas in deductive systems, which leads to shorter proofs of metalogical results.
The cost of the restrictions is that it becomes more difficult to express natural-language statements in the formal system at hand, because the logical connectives used in the natural language statements must be replaced by their (longer) definitions in terms of the restricted collection of logical connectives.
Similarly, derivations in the limited systems may be longer than derivations in systems that include additional connectives.
There is thus a trade-off between the ease of working within the formal system and the ease of proving results about the formal system.
It is also possible to restrict the arities of function symbols and predicate symbols, in sufficiently expressive theories.
One can in principle dispense entirely with functions of arity greater than 2 and predicates of arity greater than 1 in theories that include a pairing function.
This is a function of arity 2 that takes pairs of elements of the domain and returns an ordered pair containing them.
It is also sufficient to have two predicate symbols of arity 2 that define projection functions from an ordered pair to its components.
In either case it is necessary that the natural axioms for a pairing function and its projections are satisfied.
Main article: Many-sorted logic
Ordinary first-order interpretations have a single domain of discourse over which all quantifiers range.
Many-sorted first-order logic allows variables to have different sorts, which have different domains.
Many-sorted first-order logic is often used in the study of second-order arithmetic.
Additional quantifiers can be added to first-order logic.
- Sometimes it is useful to say that "P(x) holds for exactly one x", which can be expressed as ∃!x P(x). This notation, called uniqueness quantification, may be taken to abbreviate a formula such as ∃x (P(x) ∧∀y (P(y) → (x = y))).
- First-order logic with extra quantifiers has new quantifiers Qx,..., with meanings such as "there are many x such that ...". Also see branching quantifiers and the plural quantifiers of George Boolos and others.
- Bounded quantifiers are often used in the study of set theory or arithmetic.
Main article: Infinitary logic
Infinitary logic allows infinitely long sentences.
For example, one may allow a conjunction or disjunction of infinitely many formulas, or quantification over infinitely many variables.
Infinitary logic generalizes first-order logic to allow formulas of infinite length.
The most common way in which formulas can become infinite is through infinite conjunctions and disjunctions.
However, it is also possible to admit generalized signatures in which function and relation symbols are allowed to have infinite arities, or in which quantifiers can bind infinitely many variables.
Because an infinite formula cannot be represented by a finite string, it is necessary to choose some other representation of formulas; the usual representation in this context is a tree.
Thus formulas are, essentially, identified with their parse trees, rather than with the strings being parsed.
The most commonly studied infinitary logics are denoted Lαβ, where α and β are each either cardinal numbers or the symbol ∞.
In this notation, ordinary first-order logic is Lωω.
In the logic L∞ω, arbitrary conjunctions or disjunctions are allowed when building formulas, and there is an unlimited supply of variables.
More generally, the logic that permits conjunctions or disjunctions with less than κ constituents is known as Lκω.
For example, Lω1ω permits countable conjunctions and disjunctions.
The set of free variables in a formula of Lκω can have any cardinality strictly less than κ, yet only finitely many of them can be in the scope of any quantifier when a formula appears as a subformula of another.
In other infinitary logics, a subformula may be in the scope of infinitely many quantifiers.
For example, in Lκ∞, a single universal or existential quantifier may bind arbitrarily many variables simultaneously.
Similarly, the logic Lκλ permits simultaneous quantification over fewer than λ variables, as well as conjunctions and disjunctions of size less than κ.
Non-classical and modal logics
- Intuitionistic first-order logic uses intuitionistic rather than classical propositional calculus; for example, ¬¬φ need not be equivalent to φ.
- First-order modal logic allows one to describe other possible worlds as well as this contingently true world which we inhabit. In some versions, the set of possible worlds varies depending on which possible world one inhabits. Modal logic has extra modal operators with meanings which can be characterized informally as, for example "it is necessary that φ" (true in all possible worlds) and "it is possible that φ" (true in some possible world). With standard first-order logic we have a single domain and each predicate is assigned one extension. With first-order modal logic we have a domain function that assigns each possible world its own domain, so that each predicate gets an extension only relative to these possible worlds. This allows us to model cases where, for example, Alex is a Philosopher, but might have been a Mathematician, and might not have existed at all. In the first possible world P(a) is true, in the second P(a) is false, and in the third possible world there is no a in the domain at all.
- First-order fuzzy logics are first-order extensions of propositional fuzzy logics rather than classical propositional calculus.
Fixpoint logic extends first-order logic by adding the closure under the least fixed points of positive operators.
Main article: Higher-order logic
The characteristic feature of first-order logic is that individuals can be quantified, but not predicates.
is a legal first-order formula, but
is not, in most formalizations of first-order logic.
Second-order logic extends first-order logic by adding the latter type of quantification.
These higher types include relations between relations, functions from relations to relations between relations, and other higher-type objects.
Thus the "first" in first-order logic describes the type of objects that can be quantified.
Unlike first-order logic, for which only one semantics is studied, there are several possible semantics for second-order logic.
The most commonly employed semantics for second-order and higher-order logic is known as full semantics.
The combination of additional quantifiers and the full semantics for these quantifiers makes higher-order logic stronger than first-order logic.
In particular, the (semantic) logical consequence relation for second-order and higher-order logic is not semidecidable; there is no effective deduction system for second-order logic that is sound and complete under full semantics.
Second-order logic with full semantics is more expressive than first-order logic.
For example, it is possible to create axiom systems in second-order logic that uniquely characterize the natural numbers and the real line.
The cost of this expressiveness is that second-order and higher-order logics have fewer attractive metalogical properties than first-order logic.
For example, the Löwenheim–Skolem theorem and compactness theorem of first-order logic become false when generalized to higher-order logics with full semantics.
Automated theorem proving and formal methods
Further information: Automated theorem proving § First-order theorem proving
Automated theorem proving refers to the development of computer programs that search and find derivations (formal proofs) of mathematical theorems.
Finding derivations is a difficult task because the search space can be very large; an exhaustive search of every possible derivation is theoretically possible but computationally infeasible for many systems of interest in mathematics.
Thus complicated heuristic functions are developed to attempt to find a derivation in less time than a blind search.
The related area of automated proof verification uses computer programs to check that human-created proofs are correct.
Unlike complicated automated theorem provers, verification systems may be small enough that their correctness can be checked both by hand and through automated software verification.
This validation of the proof verifier is needed to give confidence that any derivation labeled as "correct" is actually correct.
Some proof verifiers, such as Metamath, insist on having a complete derivation as input.
Others, such as Mizar and Isabelle, take a well-formatted proof sketch (which may still be very long and detailed) and fill in the missing pieces by doing simple proof searches or applying known decision procedures: the resulting derivation is then verified by a small, core "kernel".
Many such systems are primarily intended for interactive use by human mathematicians: these are known as proof assistants.
They may also use formal logics that are stronger than first-order logic, such as type theory.
Because a full derivation of any nontrivial result in a first-order deductive system will be extremely long for a human to write, results are often formalized as a series of lemmas, for which derivations can be constructed separately.
Automated theorem provers are also used to implement formal verification in computer science.
Because such analysis is time-consuming and thus expensive, it is usually reserved for projects in which a malfunction would have grave human or financial consequences.
For the problem of model checking, efficient algorithms are known to decide whether an input finite structure satisfies a first-order formula, in addition to computational complexity bounds: see Model checking#First-order logic.
- ACL2 — A Computational Logic for Applicative Common Lisp.
- Extension by definitions
- Extension (predicate logic)
- Higher-order logic
- List of logic symbols
- Löwenheim number
- Prenex normal form
- Relational algebra
- Relational model
- Second-order logic
- Skolem normal form
- Tarski's World
- Truth table
- Type (model theory)
Credits to the contents of this page go to the authors of the corresponding Wikipedia page: en.wikipedia.org/wiki/First-order logic.