ML Wiki

Skolem Function

Intuition

Suppose, we have the following Conjunctive Query:

• $Q(u,v) \leftarrow T(w,u), U(v,w), R(v,u)$
• For this query, FOL meaning is
• $\forall \ u, v \ \Big[ Q(u, v) \Rightarrow \exists \ w \ : \ T(w, u) \land U(v, w) \land R(v, u) \Big]$

Now consider that we have a tuple $(a, b)$

• $(a, b)$ belongs to the data source that backs $V_1$
• so we have a fact $Q(a, b)$
• from this fact $Q(a, b)$ can infer that $R(b, a)$
• $Q(a, b) \Rightarrow R(b, a)$
• (all conjuncts have to be true for a statement to be true, so it means the last conjuncts holds true)

But we can infer other things as well

• e.g. $Q(a, b) \Rightarrow \exists \ d_1 \ : \ T(d_1, a) \land U(b, d_1)$
• where $d_1$ is some constant
• we don't know its value, but we know it exists (since it's existentially qualified) and
• it depends on constants $a$ and $b$
• so we can denote this dependency as $d_1 = f_1(a, b)$

Skolem Function

• the symbol $f_1(u, v)$ is a Skolem Function of arity 2
• $f_1(u, v)$ denotes that there exists some constant that depends on values of $u$ and $v$
• given two distinct Skolem terms, e.g. $f_1(1, 2)$ and $f_1(2, v_3)$ we never can say if they belong to the same constant or not