# Finite model theory

**Finite Model Theory** (FMT) is a subarea of model theory (MT). MT is the branch of mathematical logic which deals with the relation between a formal language (syntax) and its interpretations (semantics). FMT is a restriction of MT to interpretations of finite structures, which have a finite universe.

- Since many central theorems of MT do not hold when restricted to finite structures, FMT is quite different from MT in its methods of proof. Central results of classical model theory that fail for finite structures include the compactness theorem, Gödel's completeness theorem, and the method of ultraproducts for first-order logic (FO).
- As MT is closely related to mathematical algebra, FMT became an "unusually effective"
^{1}instrument in computer science. In other words: "In the history of mathematical logic most interest has concentrated on infinite structures....Yet, the objects computers have and hold are always finite. To study computation we need a theory of finite structures."^{2}Thus the main application areas of FMT are: descriptive complexity theory, database theory and formal language theory. - FMT is mainly about discrimination of structures. The usual motivating question is whether a given class of structures can be described (up to isomorphism) in a given language. For instance, can all cyclic graphs be discriminated (from the non-cyclic ones) by a sentence of first-order logic? This can also be phrased as: is the property "cyclic" FO expressible?

## Basic Challenges

A single structure can always be uniquely described in first-order logic. Some finite sets of structures can also be described in FO. However, FO is not sufficient to describe any set containing infinite structures.

### Characterisation of a Single Structure

Is a language L expressive enough to describe a single finite structure S uniquely (up to isomorphism)?

#### Problem

A structure like (1) in the figure can be described by FO sentences like

- Every node has an edge to another node:
- No node has an edge to itself:
- There is at least one node that is connected to all others:

However, these properties do not describe the structure uniquely (up to isomorphism), since for structure (1') the above properties hold as well, yet structures (1) and (1') are not isomorphic.

Informally the question is whether by adding enough properties, these properties together describe exactly (1) and are valid (all together) for no other structure (up to isomorphism).

#### Approach

For a single finite structure it is always possible to precisely describe the structure by a single FO sentence. The principle is illustrated here for a structure with one binary relation and without constants:

- say that there are at least elements:
- say that there are at most elements:
- state every element of the relation :
- state every non-element of the relation :

all for the same tuple , yielding the FO sentence .

#### Extension to a fixed Number of Structures

The method of describing a single structure by means of a first-order sentence can easily be extended for any fixed number of structures. A unique description can be obtained by the disjunction of the descriptions for each structure. For instance, for 2 structures this would be

#### Extension to an infinite Structure

By definition, a set containing an infinite structure falls outside the area that FMT deals with. Note that infinite structures can never be discriminated in FO because of the compactness theorem of classical MT: for every infinite model a non-isomorphic one can be found, but which has exactly the same FO properties.

The most famous example is probably Skolem's theorem, that there is a countable non-standard model of arithmetic.

### Characterisation of a Class of Structures

Is a language L expressive enough to describe exactly those finite structures that have certain property P in common (up to isomorphism)?

#### Problem

The descriptions given so far all specify the number of elements of the universe. Unfortunately most interesting sets of structures are not restricted to a certain size, like all graphs that are trees, are connected or are acyclic. Thus to discriminate a finite number of structures is of special importance.

#### Approach

Instead of a general statement, the following is a sketch of a methodology to differentiate between structures that can and cannot be discriminated.

**1.** The core idea is that whenever one wants to see if a Property P can be expressed in FO, one chooses structures A and B, where A does have P and B doesn't. If for A and B the same FO sentences hold, then P cannot be expressed in FO (else it can). In short:

and

where is shorthand for for all FO-sentences α, and P represents the class of structures with property P.

**2.** The methodology considers countably many subsets of the language, the union of which forms the language itself. For instance, for FO consider classes FO[m] for each m. For each m the above core idea then has to be shown. That is:

and

with a pair for each and α (in ≡) from FO[m]. It may be appropriate to choose the classes FO[m] to form a partition of the language.

**3.** One common way to define FO[m] is by means of the quantifier rank qr(α) of a FO formula α, which expresses the depth of quantifier nesting. For example for a formula in prenex normal form, qr is simply the total number of its quantifiers. Then FO[m] can be defined as all FO formulas α with qr(α) ≤ m (or, if a partition is desired, as those FO formulas with quantifier rank equal to m).

**4.** Thus it all comes down to showing on the subsets FO[m]. The main approach here is to use the algebraic characterization provided by Ehrenfeucht–Fraïssé games. Informally, these take a single partial isomorphism on A and B and extend it m times, in order to either prove or disprove , dependent on who wins the game.

#### Example

We want to show that the property that the size of an orderered structure **A**=(A, ≤) is even, can not be expressed in FO.

**1.** The idea is to pick **A** ∈ EVEN and **B** ∉ EVEN, where EVEN is the class of all structures of even size.

**2.** We start with 2 ordered structures **A _{2}** and

**B**with universes A

_{2}_{2}= {1, 2, 3, 4} and B

_{2}= {1, 2, 3, 4, 5}. Obviously

**A**∈ EVEN and

_{2}**B**∉ EVEN.

_{2}**3.** For m = 2, we can now show* that in a 2-move Ehrenfeucht–Fraïssé game on **A _{2}** and

**B**the duplicator always wins, and thus

_{2}**A**and

_{2}**B**cannot be discriminated in FO[2], i.e.

_{2}**A**α ⇔

_{2}**B**α for every α ∈ FO[2].

_{2}**4.** Next we have to scale the structures up by increasing m. For example, for m = 3 we must find an **A _{3}** and

**B**such that the duplicator always wins the 3-move game. This can be achieved by A

_{3}_{3}= {1, ..., 8} and B

_{3}= {1, ..., 9}. More generally, we can choose A

_{m}= {1, ..., 2

^{m}} and B

_{m}= {1, ..., 2

^{m}+1}; for any m the duplicator always wins the m-move game for this pair of structures*.

**5.** Thus EVEN on finite ordered structures cannot be expressed in FO.

(*) Note that the proof of the result of the Ehrenfeucht–Fraïssé game has been omitted, since it is not the main focus here.

## Applications

### Database Theory

A substantial fragment of SQL (namely that which is effectively relational algebra) is based on first-order logic (more precisely can be translated in domain relational calculus by means of Codd's theorem), as the following example illustrates: Think of a database table "GIRLS" with the columns "FIRST_NAME" and "LAST_NAME". This corresponds to a binary relation, say G(f, l) on FIRST_NAME X LAST_NAME. The FO query **{l : G('Judy', l)}**, which returns all the last names where the first name is 'Judy', would look in SQL like this:

select LAST_NAME from GIRLS where FIRST_NAME = 'Judy'

Notice, we assume here, that all last names appear only once (or we should use SELECT DISTINCT since we assume that relations and answers are sets, not bags).

Next we want to make a more complex statement. Therefore in addition to the "GIRLS" table we have a table "BOYS" also with the columns "FIRST_NAME" and "LAST_NAME". Now we want to query the last names of all the girls that have the same last name as at least one of the boys. The FO query is **{(f,l) : ∃h ( G(f, l) ∧ B(h, l) )}**, and the corresponding SQL statement is:

select FIRST_NAME, LAST_NAME from GIRLS where LAST_NAME IN ( select LAST_NAME from BOYS );

Notice that in order to express the "∧" we introduced the new language element "IN" with a subsequent select statement. This makes the language more expressive for the price of higher difficulty to learn and implement. This is a common trade-off in formal language design. The way shown above ("IN") is by far not the only one to extend the language. An alternative way is e.g. to introduce a "JOIN" operator, that is:

select distinct g.FIRST_NAME, g.LAST_NAME from GIRLS g, BOYS b where g.LAST_NAME=b.LAST_NAME;

First-order logic is too restrictive for some database applications, for instance because of its inability to express transitive closure. This has led to more powerful constructs being added to database query languages, such as recursive WITH in SQL:1999. More expressive logics, like fixpoint logics, have therefore been studied in finite model theory because of their relevance to database theory and applications.

### Querying & Search

Narrative data contains no defined relations. Thus the logical structure of text search queries can be expressed in Propositional Logic, like in:

("Java" AND NOT "island") OR ("C#" AND NOT "music")

Note that the challenges in full text search are different from database querying, like ranking of results.

## History

- Trakhtenbrot 1950: failure of completeness theorem in FO,
- Scholz 1952: characterisation of spectra in FO,
- Fagin 1974: the set of all properties expressible in existential second-order logic is precisely the complexity class NP,
- Chandra, Harel 1979/ 80: fixed-point FO extension for db query languages capable of expressing transitive closure -> queries as central objects of FMT.
- Immerman, Vardi 1982: fixed point logic over ordered structures captures PTIME -> descriptive complexity (... Immerman–Szelepcsényi theorem)
- Ebbinghaus, Flum 1995: First comprehensive book "Finite Model Theory"
- Abiteboul, Hull, Vianu 1995: Book "Foundations of Databases"
- Immerman 1999: Book "Descriptive Complexity"
- Kuper, Libkin, Paredaens 2000: Book "Constraint Databases"
- Darmstadt 2005/ Aachen2006: first international workshops on "Algorithmic Model Theory"

## Citations

**^**Fagin, Ronald (1993). "Finite-model theory – a personal perspective".*Theoretical Computer Science***116**: 3–31. doi:10.1016/0304-3975(93)90218-I.**^**Immerman, Neil (1999).*Descriptive Complexity*. New York: Springer-Verlag. p. 6. ISBN 0-387-98600-6.

## External links

Wikibooks has a book on the topic of: Finite Model Theory |

- Libkin, Leonid (2009). "The finite model theory toolbox of a database theoretician".
*PODS 2009: Proceedings of the twenty-eighth ACM SIGACT–SIGMOD symposium on Principles of database systems*. pp. 65–76. doi:10.1145/1559795.1559807. Also suitable as a general introduction and overview. - Leonid Libkin. Introductory chapter of "Elements of Finite Model Theory". Motivates three main application areas: databases, complexity and formal languages.
- Jouko Väänänen. A Short Course on Finite Model Theory. Department of Mathematics, University of Helsinki. Based on lectures from 1993-1994.
- Anuj Dawar. Infinite and Finite Model Theory, slides, University of Cambridge, 2002.
- "Algorithmic Model Theory". RWTH Aachen. Retrieved 7 November 2013. Includes a list of open FMT problems.

## References

- Ebbinghaus, Heinz-Dieter; Flum, Jörg (1995).
*Finite Model Theory*. Springer. ISBN 978-3-540-60149-4.

- Libkin, Leonid (2004).
*Elements of Finite Model Theory*. Springer. ISBN 3-540-21202-7.

- Abiteboul, Serge; Hull, Richard; Vianu, Victor (1995).
*Foundations of Databases*. Addison-Wesley. ISBN 0-201-53771-0.

- Immerman, Neil (1999).
*Descriptive Complexity*. New York: Springer. ISBN 0-387-98600-6.

HPTS - Area Progetti - Edu-Soft - JavaEdu - N.Saperi - Ass.Scuola.. - TS BCTV - TS VideoRes - TSODP - TRTWE | ||