First order logic
Whereas propositional logic assumes the world contains statements, first-order logic (like natural language) assumes the world contains:
- objects
- statements in form of relations (predicates) between objects
Syntax
Basic elements
- Constant symbols: KingJohn, 2, POLIMI, ...
- Predicate symbols: Brother, >, ...
- Function symbols: Sqrt, LeftLegOf, ...
- Variables: π₯, π¦, π, π, ...
- Connectives: $\lnot$, $\to$, $\land$, $\lor$, $\iff$
- Equality: $=$
- Quantifiers: $\forall$, $\exists$
Terms and sentences
A term denotes an object in the form: function(term1,...,termn), constant, variable.
An atomic sentence is in the form predicate(term1,...,termn) or term1 = term2.
A complex sentence is made from atomic sentences using connectives, for example: $\lnot \alpha$, $\alpha \land \beta$, $Brother(KingJohn,Richard) \to Brother(Richard,KingJohn)$
Semantics
Sentences are true with respect to a model and an interpretation.
The model contains objects (domain elements) and relations among them while the interpretation specifies referents for:
- constant symbols β objects
- predicate symbols β relations
- function symbols β functions
An atomic sentence predicate(term1,...,termn) is true when the objects referred to by term1,...,termn are in the relation referred to by predicate and a complex sentence is true with the usual rules for connectives.
Universal quantification
Everyone at POLIMI is smart: $\forall x At(x, POLIMI) \to Smart(x)$
$\forall x P$ is true in a model $M$ $\iff$ $P$ is true with $x$ being each possible object in the model. Roughly speaking, universal quantification is equivalent to the conjunction of instantiations of π.
Typically, $\to$ is the main connective with $\forall$. A common mistake is using $\land$ as the main connective with $\forall$: $\forall x At(x, POLIMI) \land Smart(x)$ means "Everyone is at POLIMI and everyone is smart".
Existential quantification
Someone at POLIMI is smart: $\exists x At(x, POLIMI) \land Smart(x)$
$\exists x P$ is true in a model $M$ $\iff$ $P$ is true with $x$ being some possible object in the model. Roughly speaking, universal quantification is equivalent to the disjunction of instantiations of π.
Typically, $\land$ is the main connective with $\exists$. A common mistake is using $\to$ as the main connective with $\exists$: $\exists x At(x, POLIMI) \to Smart(x)$.
Properties of quantifiers
$\forall x \forall y$ is the same as $\forall y \forall x$ and $\exists x \exists y$ is the same as $\exists y \exists x$.
$\forall x \exists y$ is not the same as $\exists x \forall y$:
- $\exists x \forall y Loves(π₯, π¦)$ means βThere is a person who loves everyone in the worldβ
- $\forall x \exists y Loves(π₯, π¦)$ means βEveryone in the world is loved by at least one personβ
Quantifier duality: each can be expressed using the other:
- $\forall π₯ Likes(π₯, IceCream) β‘ \lnot \exists π₯ \lnot Likes(π₯, IceCream)$
- $\exists π₯ Likes(π₯, Broccoli) β‘ \lnot \forall π₯ \lnot Likes(π₯, Broccoli)$
Translation from first order logic to propositional logic
The translation is possible when the domain of discourse contains only a finite number of objects.
- Systematically replace all variables with the available constants, considering that in case, e.g., of constants $A_1$ to $A_n$:
- $\forall x P(x)$ becomes $P(A_1) \land ... \land P(A_n)$
- $\exists x P(x)$ becomes $P(A_1) \lor ... \lor P(A_n)$
- The atomic sentences $P(A_i)$ are replaced by propositional symbols:
- $P(A_1) \land ... \land P(A_n)$ becomes $PA_1 \land ... \land PA_n$
- $P(A_1) \lor ... \lor P(A_n)$ becomes $PA_1 \lor ... \lor PA_n$
The number of propositional symbols can be limited by considering that some assignments of constant to variables are meaningless.
Examples:
Natural language | First order logic | Propositional logic |
---|---|---|
Those who like opera, like both music and theatre | $\forall x (L(x, O) \to L(x,M) \land L(x,T))$ | $(πΏπ΄π β πΏπ΄π β§ πΏπ΄π) β§ (πΏπ΅π β πΏπ΅π β§ πΏπ΅π)$ |
Alice likes music, but she does not like theatre | $L(A,M) \land \lnot L(A,T)$ | $πΏπ΄π β§ Β¬πΏπ΄π$ |
Bob likes exactly the same things that Alice likes | $\forall x (L(A,x) β L(B,x))$ | $(πΏπ΅π β πΏπ΄π) β§ (πΏπ΅π β πΏπ΄π) β§ (πΏπ΅π β πΏπ΄π)$ |
Bob does not like opera | $\lnot L(B,O)$ | $Β¬πΏπ΅π$ |