1 Introduction
 Program completion (Clark Reference Clark1978) is a translation from the language of logic programs into the language of first-order theories. If, for example, a program defines the predicate 
 $q/1$
 by the rules
$q/1$
 by the rules 
 \begin{equation}\begin{array} lq(a),\\q(X) \leftarrow p(X),\end{array}\end{equation}
\begin{equation}\begin{array} lq(a),\\q(X) \leftarrow p(X),\end{array}\end{equation}
 then the completed definition of 
 $q/1$
 is
$q/1$
 is 
 \begin{equation}\forall X(q(X)\leftrightarrow X=a \lor p(X)).\end{equation}
\begin{equation}\forall X(q(X)\leftrightarrow X=a \lor p(X)).\end{equation}
Program (1) and formula (2) express, in different languages, the same idea: the set q consists of a and all elements of p.
Fages (Reference Fages1994) identified a class of programs for which the completion semantics is equivalent to the stable model semantics. Programs in this class are now called tight. This relationship between completion and stable models plays an important role in the theory of answer set programming (ASP). It is used in the design of the answer set solvers cmodels (Lierler and Maratea Reference Lierler and Maratea2004), assat (Lin and Zhao Reference Lin and Zhao2004) and clasp (Gebser et al. Reference Gebser, Schaub and Thiele2007); and in the design of the proof assistants anthem (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020) and anthem-p2p (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023).
Some constructs that are common in ASP programs are not covered by Clark’s definition of program completion, and that definition had to be generalized. First, the original definition does not cover programs that involve integer arithmetic. To extend it to such programs, we distinguish, in the corresponding first-order formula, between “general” variables on the one hand, and variables for integers on the other (Lifschitz et al. Reference Lifschitz, Lühne and Schaub2019, Section 5). This is useful because function symbols in a first-order language are supposed to represent total functions, and arithmetical operations are not defined on symbolic constants.
Second, in ASP programs we often find auxiliary predicate symbols, which are not considered part of its output. Consider, for instance, the program
 \begin{align} \textit{in}(P,R,0) &\leftarrow \textit{in}_0(P,R),\end{align}
\begin{align} \textit{in}(P,R,0) &\leftarrow \textit{in}_0(P,R),\end{align}
 \begin{align}\textit{in}(P,R,T+ 1) &\leftarrow \textit{goto}(P,R,T),\end{align}
\begin{align}\textit{in}(P,R,T+ 1) &\leftarrow \textit{goto}(P,R,T),\end{align}
 \begin{align}\{\,\textit{in}(P,R,T+ 1)\,\} &\leftarrow \textit{in}(P,R,T) \land T = 0\,..\,h- 1,\end{align}
\begin{align}\{\,\textit{in}(P,R,T+ 1)\,\} &\leftarrow \textit{in}(P,R,T) \land T = 0\,..\,h- 1,\end{align}
 \begin{align}&\leftarrow \textit{in}(P,R_1,T)\land \textit{in}(P,R_2,T)\land R_1 \neq R_2,\end{align}
\begin{align}&\leftarrow \textit{in}(P,R_1,T)\land \textit{in}(P,R_2,T)\land R_1 \neq R_2,\end{align}
 \begin{align}\textit{in_building}(P,T) &\leftarrow \textit{in}(P,R,T),\end{align}
\begin{align}\textit{in_building}(P,T) &\leftarrow \textit{in}(P,R,T),\end{align}
 \begin{align}&\leftarrow \textit{not}\ \textit{in_building}(P,T)\land \textit{person}(P) \land T = 0\,..\,h,\end{align}
\begin{align}&\leftarrow \textit{not}\ \textit{in_building}(P,T)\land \textit{person}(P) \land T = 0\,..\,h,\end{align}
which will be used as a running example. It describes the effect of an action – walking from one room to another – on the location of a person. We can read 
 $\textit{in}(P,R,T)$
 as “person P is in room R at time T,” and
$\textit{in}(P,R,T)$
 as “person P is in room R at time T,” and 
 $\textit{goto}(P,R,T)$
 as “person P goes to room R between times T and
$\textit{goto}(P,R,T)$
 as “person P goes to room R between times T and 
 $T+1$
.” The placeholder h represents the horizon – the length of scenarios under consideration. Choice rule (5) encodes the commonsense law of inertia for this dynamic system: in the absence of information to the contrary, the location of a person at time
$T+1$
.” The placeholder h represents the horizon – the length of scenarios under consideration. Choice rule (5) encodes the commonsense law of inertia for this dynamic system: in the absence of information to the contrary, the location of a person at time 
 $T+1$
 is presumed to be the same as at time T. To run this program, we need to specify the value of h and the input predicates person/1,
$T+1$
 is presumed to be the same as at time T. To run this program, we need to specify the value of h and the input predicates person/1, 
 $\textit{in}_0/2$
 and goto/3. The output is represented by the atoms in the stable model that contain in/3. The predicate symbol in_building/2 is auxiliary; a file containing program (3)–(8) may contain a directive that causes the solver not to display the atoms containing that symbol.
$\textit{in}_0/2$
 and goto/3. The output is represented by the atoms in the stable model that contain in/3. The predicate symbol in_building/2 is auxiliary; a file containing program (3)–(8) may contain a directive that causes the solver not to display the atoms containing that symbol.
For this program and other programs containing auxiliary symbols, we would like the completion to describe the “essential parts” of its stable models, with all auxiliary atoms removed. This can be accomplished by replacing the auxiliary symbols in Clark’s completion by existentially quantified predicate variables (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Section 6.2). The version of completion defined in that paper covers both integer arithmetic and the distinction between the entire stable model and its essential part. Standard models of the completion, in the sense of that paper, correspond to the essential parts of the program’s stable models if the program is tight (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Theorem 2, reproduced in Section 3.3 below).
That theorem is not applicable, however, to program (3)–(8), because this program is not tight. Tightness is defined as the absence of certain cyclical dependencies between predicate symbols (see Section 3.3 for details). The two occurrences of the predicate in/3 in rule (5) create a dependency that is not allowed in a tight program.
 In this article we propose the definition of a “locally tight” program and show that the above-mentioned theorem by Fandinno et al. can be extended to programs satisfying this less restrictive condition. Local tightness is defined in terms of dependencies between ground atoms. The last argument of in/3 in the head of rule (3)–(8) is 
 $T+1$
, and the last argument of in/3 in the body is T; for this reason, the dependencies between ground atoms corresponding to this rule are not cyclic. ASP encodings of dynamic systems (Lifschitz Reference Lifschitz2019, Chapter 8) provide many examples of this kind. The tightness condition prohibits pretty much all uses of recursion in a program; local tightness, on the other hand, expresses the absence of “nonterminating” recursion.
$T+1$
, and the last argument of in/3 in the body is T; for this reason, the dependencies between ground atoms corresponding to this rule are not cyclic. ASP encodings of dynamic systems (Lifschitz Reference Lifschitz2019, Chapter 8) provide many examples of this kind. The tightness condition prohibits pretty much all uses of recursion in a program; local tightness, on the other hand, expresses the absence of “nonterminating” recursion.
The result of this article shows, for example, that the completion of program (3)–(8) correctly describes the essential parts of its stable models.
Section 2 is a review of definitions and notation related to ASP programs with arithmetic. After defining program completion in Section 3, we introduce locally tight programs and state a theorem describing the relationship between stable models and completion under a local tightness assumption (Section 4). In Section 5, that theorem is used to justify the usability of the proof assistant anthem-p2p for verifying equivalence between programs in some cases that are not allowed in the original publication (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023). Proofs of the theorems stated in these sections are based on a lemma of more general nature, which relates stable models to completion for a class of many-sorted first-order theories. This Main Lemma is stated in Section 6 and proved in Section 7. Proofs of the theorems are given in Sections 8–10. In two appendices, we review terminology and notation related to many-sorted formulas and their stable models.
2 Background
This review follows previous publications on ASP programs with arithmetic (Lifschitz et al. Reference Lifschitz, Lühne and Schaub2019; Fandinno et al. 2020; Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023).
2.1 Programs
The programming language mini-gringo, defined in this section, is a subset of the input language of the grounder gringo (Gebser et al. Reference Gebser, Schaub and Thiele2007). Most constructs included in this language are available also in the input language of the solver dlv (Leone et al. Reference Leone, Pfeifer, Faber, Eiter, Gottlob, Perri and Scarcello2006). The description of mini-gringo programs below uses “abstract syntax,” which disregards some details related to representing programs by strings of ASCII characters (Gebser et al. Reference Gebser, Harrison, Kaminski, Lifschitz and Schaub2015).
2.1.1 Syntax
 We assume that three countably infinite sets of symbols are selected: numerals, symbolic constants, and variables. We assume that a 1-1 correspondence between numerals and integers is chosen; the numeral corresponding to an integer n is denoted by 
 $\overline{n}$
. In examples, we take the liberty to drop the overline in numerals. This convention is used, for instance, in rule (5), which should be written, strictly speaking, as
$\overline{n}$
. In examples, we take the liberty to drop the overline in numerals. This convention is used, for instance, in rule (5), which should be written, strictly speaking, as 

 Precomputed terms are numerals and symbolic constants. We assume that a total order on precomputed terms is chosen such that for all integers m and n, 
 $\overline{m} < \overline{n}$
 iff
$\overline{m} < \overline{n}$
 iff 
 $m<n$
.
$m<n$
.
 Terms allowed in a mini-gringo program are formed from precomputed terms and variables using the absolute value symbol 
 $|\,|$
 and six binary operation names
$|\,|$
 and six binary operation names 
 $$+\quad-\quad\times\quad/\quad\backslash \quad.$$
$$+\quad-\quad\times\quad/\quad\backslash \quad.$$
 An atom is a symbolic constant optionally followed by a tuple of terms in parentheses. A literal is an atom possibly preceded by one or two occurrences of not. A comparison is an expression of the form 
 $t_1\;\mathit{rel}\; t_2$
, where
$t_1\;\mathit{rel}\; t_2$
, where 
 $t_1$
,
$t_1$
, 
 $t_2$
 are terms and
$t_2$
 are terms and 
 $\mathit{rel}$
 is
$\mathit{rel}$
 is 
 $=$
 or one of the comparison symbols
$=$
 or one of the comparison symbols 
 \begin{equation}\neq\quad<\quad>\quad\leq\quad\geq.\end{equation}
\begin{equation}\neq\quad<\quad>\quad\leq\quad\geq.\end{equation}
 A rule is an expression of the form 
 $\mathit{Head}\leftarrow\mathit{Body}$
, where
$\mathit{Head}\leftarrow\mathit{Body}$
, where
- 
•  $\mathit{Body}$
 is a conjunction (possibly empty) of literals and comparisons, and $\mathit{Body}$
 is a conjunction (possibly empty) of literals and comparisons, and
- 
•  $\mathit{Head}$
 is either an atom (then this is a basic rule), or an atom in braces (then this is a choice rule), or empty (then this is a constraint). $\mathit{Head}$
 is either an atom (then this is a basic rule), or an atom in braces (then this is a choice rule), or empty (then this is a constraint).
 A rule is ground if it does not contain variables. A ground rule of the form 
 $\mathit{Head}\leftarrow$
, where
$\mathit{Head}\leftarrow$
, where 
 $\mathit{Head}$
 is an atom, will be identified with the atom
$\mathit{Head}$
 is an atom, will be identified with the atom 
 $\mathit{Head}$
 and called a fact.
$\mathit{Head}$
 and called a fact.
A program is a finite set of rules.
 A predicate symbol is a pair 
 $p/n$
, where p is a symbolic constant, and n is a nonnegative integer. We say that
$p/n$
, where p is a symbolic constant, and n is a nonnegative integer. We say that 
 $p/n$
 occurs in a literal l if l contains an atom of the form
$p/n$
 occurs in a literal l if l contains an atom of the form 
 $p(t_1,\dots,t_n)$
, and similarly for occurrences in rules and in other syntactic expressions.
$p(t_1,\dots,t_n)$
, and similarly for occurrences in rules and in other syntactic expressions.
 An atom 
 $p(t_1,\dots,t_n)$
 is precomputed if the terms
$p(t_1,\dots,t_n)$
 is precomputed if the terms 
 $t_1,\dots,t_n$
 are precomputed.
$t_1,\dots,t_n$
 are precomputed.
2.1.2 Semantics
The semantics of ground terms is defined by assigning to every ground term t a finite set [t] of precomputed terms called its values. It is recursively defined as follows:
- • if t is a numeral or a symbolic constant, then [t] is the singleton set  $\{t\}$
; $\{t\}$
;
- • if t is  $|t_1|$
, then [t] is the set of numerals $|t_1|$
, then [t] is the set of numerals $\overline{|n|}$
 for all integers n such that $\overline{|n|}$
 for all integers n such that $\overline{n} \in [t_1]$
; $\overline{n} \in [t_1]$
;
- • if t is  $(t_1 + t_2)$
, then [t] is the set of numerals $(t_1 + t_2)$
, then [t] is the set of numerals $\overline{n_1 + n_2}$
 for all integers $\overline{n_1 + n_2}$
 for all integers $n_1$
, $n_1$
, $n_2$
 such that $n_2$
 such that $\overline{n_1} \in [t_1]$
 and $\overline{n_1} \in [t_1]$
 and $\overline{n_2} \in [t_2]$
; similarly when t is $\overline{n_2} \in [t_2]$
; similarly when t is $(t_1 - t_2)$
 or $(t_1 - t_2)$
 or $(t_1 \times t_2)$
; $(t_1 \times t_2)$
;
- • if t is  $(t_1/t_2)$
, then [t] is the set of numerals $(t_1/t_2)$
, then [t] is the set of numerals $\overline{\mathit{round}(n_1/n_2)}$
 for all integers $\overline{\mathit{round}(n_1/n_2)}$
 for all integers $n_1$
, $n_1$
, $n_2$
 such that $n_2$
 such that $n_1 \in [t_1]$
, $n_1 \in [t_1]$
, $n_2 \in [t_2]$
, and $n_2 \in [t_2]$
, and $n_2 \neq 0$
; $n_2 \neq 0$
;
- • if t is  $(t_1 \backslash t_2)$
, then [t] is the set of numerals $(t_1 \backslash t_2)$
, then [t] is the set of numerals $\overline{n_1 - n_2 \cdot \mathit{round}(n_1/n_2)}$
 for all integers $\overline{n_1 - n_2 \cdot \mathit{round}(n_1/n_2)}$
 for all integers $n_1$
, $n_1$
, $n_2$
 such that $n_2$
 such that $n_1 \in [t_1]$
, $n_1 \in [t_1]$
, $n_2 \in [t_2]$
, and $n_2 \in [t_2]$
, and $n_2 \neq 0$
; $n_2 \neq 0$
;
- • if t is  $(t_1..t_2)$
, then [t] is the set of numerals $(t_1..t_2)$
, then [t] is the set of numerals $\overline{m}$
 for all integers m such that, for some integers $\overline{m}$
 for all integers m such that, for some integers $n_1$
, $n_1$
, $n_2$
, $n_2$
, $n_1 \in [t_1]$
, $n_1 \in [t_1]$
, $n_2 \in [t_2]$
, $n_2 \in [t_2]$
, $n_1 \leq m \leq n_2$
; $n_1 \leq m \leq n_2$
;
 where the function 
 $\mathit{round}$
 is defined as follows:
$\mathit{round}$
 is defined as follows: 
 \begin{gather*} \mathit{round}(n) = \begin{cases} \lfloor n \rfloor & \text{if $n \geq 0$}, \\ \lceil n \rceil & \text{if $n < 0$}. \end{cases}\end{gather*}
\begin{gather*} \mathit{round}(n) = \begin{cases} \lfloor n \rfloor & \text{if $n \geq 0$}, \\ \lceil n \rceil & \text{if $n < 0$}. \end{cases}\end{gather*}
The use of this function reflects the fact that the grounder gringo (Gebser et al. Reference Gebser, Kaminski, Kaufmann, Lindauer, Ostrowski, Romero, Schaub and Thiele2019) truncates non-integer quotients toward zero. This feature of gringo was not taken into account in earlier publications (Gebser et al. Reference Gebser, Harrison, Kaminski, Lifschitz and Schaub2015, Section 4.2; Lifschitz et al. Reference Lifschitz, Lühne and Schaub2019, Section 6; Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Section 3), where the floor function was used.
For instance,
 $$[\overline{7}/\overline{2}]=\{\overline{3}\},\;[\overline{0}\,..\,\overline{2}]=\{\overline{0}, \overline{1}, \overline{2}\},\;[\overline{2}/\overline{0}] = [\overline{2}\,..\,\overline{0}] = \emptyset;$$
$$[\overline{7}/\overline{2}]=\{\overline{3}\},\;[\overline{0}\,..\,\overline{2}]=\{\overline{0}, \overline{1}, \overline{2}\},\;[\overline{2}/\overline{0}] = [\overline{2}\,..\,\overline{0}] = \emptyset;$$
 
 $[\overline{2}+c] = [\overline{2}\,..\,c] = \emptyset$
 if c is a symbolic constant.
$[\overline{2}+c] = [\overline{2}\,..\,c] = \emptyset$
 if c is a symbolic constant.
 For any ground terms 
 $t_1, \dots, t_n$
, by
$t_1, \dots, t_n$
, by 
 $[t_1, \dots, t_n]$
 we denote the set of tuples
$[t_1, \dots, t_n]$
 we denote the set of tuples 
 $r_1, \dots, r_n$
 for all
$r_1, \dots, r_n$
 for all 
 $r_1 \in [t_1], \dots, r_n \in[t_n]$
.
$r_1 \in [t_1], \dots, r_n \in[t_n]$
.
 The semantics of programs is defined by rewriting rules in the syntax of propositional logic and referring to the definition of a stable model (answer set) of a propositional theory (Ferraris Reference Ferraris2005). The transformation 
 $\tau$
 is defined as follows. For any ground atom
$\tau$
 is defined as follows. For any ground atom 
 $p(\mathbf{t})$
, where
$p(\mathbf{t})$
, where 
 $\mathbf{t}$
 is a tuple of terms,
$\mathbf{t}$
 is a tuple of terms,
- •  $\tau (p(\mathbf{t}))$
 stands for $\tau (p(\mathbf{t}))$
 stands for $\bigvee_{\mathbf{r} \in [\mathbf{t}]} p(\mathbf{r})$
, $\bigvee_{\mathbf{r} \in [\mathbf{t}]} p(\mathbf{r})$
,
- •  $\tau (\mathit{not} p(\mathbf{t}))$
 stands for $\tau (\mathit{not} p(\mathbf{t}))$
 stands for $\bigvee_{\mathbf{r} \in [\mathbf{t}]} \neg p(\mathbf{r})$
, and $\bigvee_{\mathbf{r} \in [\mathbf{t}]} \neg p(\mathbf{r})$
, and
- •  $\tau (\mathit{not} \mathit{not} p(\mathbf{t}))$
 stands for $\tau (\mathit{not} \mathit{not} p(\mathbf{t}))$
 stands for $\bigvee_{\mathbf{r} \in [\mathbf{t}]} \neg\neg p(\mathbf{r})$
. $\bigvee_{\mathbf{r} \in [\mathbf{t}]} \neg\neg p(\mathbf{r})$
.
 For any ground comparison 
 $t_1 \mathit{rel} t_2$
, we define
$t_1 \mathit{rel} t_2$
, we define 
 $\tau(t_1 \mathit{rel} t_2)$
 as
$\tau(t_1 \mathit{rel} t_2)$
 as
- •  $\top$
 if the relation $\top$
 if the relation $\mathit{rel}$
 holds between some $\mathit{rel}$
 holds between some $r_1$
 from $r_1$
 from $[t_1]$
 and some $[t_1]$
 and some $r_2$
 from $r_2$
 from $[t_2]$
; $[t_2]$
;
- •  $\bot$
 otherwise. $\bot$
 otherwise.
 If each of 
 $C_1,\dots, C_k$
 is a ground literal or a ground comparison, then
$C_1,\dots, C_k$
 is a ground literal or a ground comparison, then 
 $\tau(C_1\land \cdots \land C_k)$
 stands for
$\tau(C_1\land \cdots \land C_k)$
 stands for 
 $\tau C_1\land \cdots \land \tau C_k$
.
$\tau C_1\land \cdots \land \tau C_k$
.
 If R is a ground basic rule 
 $p(\mathbf{t}) \leftarrow \mathit{Body}$
, then
$p(\mathbf{t}) \leftarrow \mathit{Body}$
, then 
 $\tau R$
 is the propositional formula
$\tau R$
 is the propositional formula 
 \[\textstyle\tau(\mathit{Body}) \rightarrow\bigwedge_{\mathbf{r}\in [\mathbf{t}]} p(\mathbf{r}).\]
\[\textstyle\tau(\mathit{Body}) \rightarrow\bigwedge_{\mathbf{r}\in [\mathbf{t}]} p(\mathbf{r}).\]
 If R is a ground choice rule 
 $\{p(\mathbf{t})\} \leftarrow \mathit{Body}$
, then
$\{p(\mathbf{t})\} \leftarrow \mathit{Body}$
, then 
 $\tau R$
 is the propositional formula
$\tau R$
 is the propositional formula 
 \[\textstyle\tau(\mathit{Body}) \rightarrow \bigwedge_{\mathbf{r} \in [\mathbf{t}]}(p(\mathbf{r})\lor\neg p(\mathbf{r})).\]
\[\textstyle\tau(\mathit{Body}) \rightarrow \bigwedge_{\mathbf{r} \in [\mathbf{t}]}(p(\mathbf{r})\lor\neg p(\mathbf{r})).\]
 If R is a ground constraint 
 $\leftarrow\mathit{Body}$
, then
$\leftarrow\mathit{Body}$
, then 
 $\tau R$
 is
$\tau R$
 is 
 $\neg\tau(\mathit{Body})$
.
$\neg\tau(\mathit{Body})$
.
 An instance of a rule is a ground rule obtained from it by substituting precomputed terms for variables. For any program 
 $\Pi$
,
$\Pi$
, 
 $\tau\Pi$
 is the set of the formulas
$\tau\Pi$
 is the set of the formulas 
 $\tau R$
 for all instances R of the rules of
$\tau R$
 for all instances R of the rules of 
 $\Pi$
. Thus
$\Pi$
. Thus 
 $\tau\Pi$
 is a set of propositional combinations of precomputed atoms.
$\tau\Pi$
 is a set of propositional combinations of precomputed atoms.
 For example, 
 $\tau$
 transforms
$\tau$
 transforms 
 $\{q(X)\} \leftarrow p(X)$
 into the set of formulas
$\{q(X)\} \leftarrow p(X)$
 into the set of formulas 
 $$p(t)\to (q(t)\lor\neg q(t)),$$
$$p(t)\to (q(t)\lor\neg q(t)),$$
 for all precomputed terms t. The rule 
 $q(\overline{0}\,..\,\overline{2}) \leftarrow \textit{not}\ p$
 is transformed into
$q(\overline{0}\,..\,\overline{2}) \leftarrow \textit{not}\ p$
 is transformed into 
 $$\neg p\to(q(\overline{0})\land q(\overline{1})\land q(\overline{2})).$$
$$\neg p\to(q(\overline{0})\land q(\overline{1})\land q(\overline{2})).$$
 
Stable models of a program are defined as stable models of the set of formulas obtained from it by applying the transformation 
 $\tau$
. Thus stable models of programs are sets of precomputed atoms. This definition is a special case of the definition proposed by Lifschitz et al. (Reference Lifschitz, Lühne and Schaub2019, Section 3) for Abstract Gringo, except for the changes in the treatment of the division and modulo operations mentioned above.
$\tau$
. Thus stable models of programs are sets of precomputed atoms. This definition is a special case of the definition proposed by Lifschitz et al. (Reference Lifschitz, Lühne and Schaub2019, Section 3) for Abstract Gringo, except for the changes in the treatment of the division and modulo operations mentioned above.
2.2 Programs with input and output
A program with input and output, or an io-program, is a quadruple
 \begin{equation}(\Pi,\textit{PH},\textit{In},\textit{Out}),\end{equation}
\begin{equation}(\Pi,\textit{PH},\textit{In},\textit{Out}),\end{equation}
where
- • PH is a finite set of symbolic constants; 
- • In is a finite set of predicate symbols, 
- • Out is a finite set of predicate symbols that is disjoint from In, 
 and 
 $\Pi$
 is a mini-gringo program such that the symbols from In do not occur in the heads of its rules. Members of PH are the placeholders of (10); members of In are the input symbols of (10); members of Out are the output symbols of (10). The input symbols and output symbols of an io-program are collectively called its public symbols. The other predicate symbols occurring in the rules are private. An input atom is an atom
$\Pi$
 is a mini-gringo program such that the symbols from In do not occur in the heads of its rules. Members of PH are the placeholders of (10); members of In are the input symbols of (10); members of Out are the output symbols of (10). The input symbols and output symbols of an io-program are collectively called its public symbols. The other predicate symbols occurring in the rules are private. An input atom is an atom 
 $p(t_1,\dots,t_n)$
 such that
$p(t_1,\dots,t_n)$
 such that 
 $p/n$
 is an input symbol. Output atoms, public atoms and private atoms are defined in a similar way.
$p/n$
 is an input symbol. Output atoms, public atoms and private atoms are defined in a similar way.
 For any set 
 $\mathcal{P}$
 of public atoms,
$\mathcal{P}$
 of public atoms, 
 $\mathcal{P}^{in}$
 stands for the set of input atoms in
$\mathcal{P}^{in}$
 stands for the set of input atoms in 
 $\mathcal{P}$
.
$\mathcal{P}$
.
 The example discussed in the introduction corresponds to program (3)–(8) as 
 $\Pi$
, and
$\Pi$
, and 
 \begin{equation}\textit{PH}=\{h\},\;\textit{In}= \{\textit{person}/1, \textit{in}_0/2, \textit{goto}/3\},\;\textit{Out}= \{\textit{in}/3\}.\end{equation}
\begin{equation}\textit{PH}=\{h\},\;\textit{In}= \{\textit{person}/1, \textit{in}_0/2, \textit{goto}/3\},\;\textit{Out}= \{\textit{in}/3\}.\end{equation}
 This io-program will be denoted by 
 $\Omega_1$
. The only private symbol of
$\Omega_1$
. The only private symbol of 
 $\Omega_1$
 is
$\Omega_1$
 is 
 $\textit{in_building}/2$
.
$\textit{in_building}/2$
.
 A valuation on a set PH of symbolic constants is a function that maps elements of PH to precomputed terms that do not belong to PH. An input for an io-program (10) is a pair 
 $(v,\mathcal{I})$
, where
$(v,\mathcal{I})$
, where
- • v is a valuation on the set PH of its placeholdlers, and 
- •  $\mathcal{I}$
 is a set of precomputed input atoms such that its members do not contain placeholders. $\mathcal{I}$
 is a set of precomputed input atoms such that its members do not contain placeholders.
 An input 
 $(v,\mathcal{I})$
 represents a way to choose the values of placeholders and the extents of input predicates: for every placeholder c, specify v(c) as its value, and add the atoms
$(v,\mathcal{I})$
 represents a way to choose the values of placeholders and the extents of input predicates: for every placeholder c, specify v(c) as its value, and add the atoms 
 $\mathcal{I}$
 to the rules of the program as facts. If
$\mathcal{I}$
 to the rules of the program as facts. If 
 $\Pi$
 is a mini-gringo program then
$\Pi$
 is a mini-gringo program then 
 $v(\Pi)$
 stands for the program obtained from
$v(\Pi)$
 stands for the program obtained from 
 $\Pi$
 by replacing every occurrence of every constant c in the domain of v by v(c). Using this notation, we can say that choosing
$\Pi$
 by replacing every occurrence of every constant c in the domain of v by v(c). Using this notation, we can say that choosing 
 $(v,\mathcal{I})$
 as input for
$(v,\mathcal{I})$
 as input for 
 $\Pi$
 amounts to replacing
$\Pi$
 amounts to replacing 
 $\Pi$
 by the program
$\Pi$
 by the program 
 $v(\Pi)\cup\mathcal{I}$
.
$v(\Pi)\cup\mathcal{I}$
.
 About a set of precomputed atoms we say that it is an io-model of an io-program (10) for an input 
 $(v,\mathcal{I})$
 if it is the set of all public atoms of some stable model of the program
$(v,\mathcal{I})$
 if it is the set of all public atoms of some stable model of the program 
 $v(\Pi)\cup\mathcal{I}$
. If
$v(\Pi)\cup\mathcal{I}$
. If 
 $\mathcal{P}$
 is an io-model of an io-program for an input
$\mathcal{P}$
 is an io-model of an io-program for an input 
 $(v,\mathcal{I})$
 then
$(v,\mathcal{I})$
 then 
 $\mathcal{P}^{in}=\mathcal{I}$
, because the only rules of
$\mathcal{P}^{in}=\mathcal{I}$
, because the only rules of 
 $v(\Pi)\cup\mathcal{I}$
 containing input symbols in the head are the facts
$v(\Pi)\cup\mathcal{I}$
 containing input symbols in the head are the facts 
 $\mathcal{I}$
.
$\mathcal{I}$
.
 For example, an input 
 $(v,\mathcal{I})$
 for the io-program
$(v,\mathcal{I})$
 for the io-program 
 $\Omega_1$
 can be defined by the conditions
$\Omega_1$
 can be defined by the conditions 
 \begin{equation}\begin{array} lv(h)=\overline{2},\\\mathcal{I}= \{\textit{person}(\textit{alice}),\textit{person}(\textit{bob}),\\\hskip 9mm\textit{in}_0(\textit{alice},\textit{hall}),\textit{in}_0(\textit{bob},\textit{hall}),\\\hskip 9mm\textit{goto}(\textit{alice},\textit{classroom},\overline{0}),\textit{goto}(\textit{bob},\textit{classroom},\overline{1})\}.\end{array}\end{equation}
\begin{equation}\begin{array} lv(h)=\overline{2},\\\mathcal{I}= \{\textit{person}(\textit{alice}),\textit{person}(\textit{bob}),\\\hskip 9mm\textit{in}_0(\textit{alice},\textit{hall}),\textit{in}_0(\textit{bob},\textit{hall}),\\\hskip 9mm\textit{goto}(\textit{alice},\textit{classroom},\overline{0}),\textit{goto}(\textit{bob},\textit{classroom},\overline{1})\}.\end{array}\end{equation}
 The program 
 $v(\Pi)\cup\mathcal{I}$
 has a unique stable model, which consists of the members of
$v(\Pi)\cup\mathcal{I}$
 has a unique stable model, which consists of the members of 
 $\mathcal{I}$
, the atoms
$\mathcal{I}$
, the atoms 
 \begin{equation}\begin{array} l\{\textit{in}(\textit{alice},hall,\overline{0}),\textit{in}(\textit{bob},hall,\overline{0}),\\\hskip 2mm\textit{in}(\textit{alice},classroom,\overline{1}),\textit{in}(\textit{bob},hall,\overline{1}),\\\hskip 2mm\textit{in}(\textit{alice},classroom,\overline{2}),\textit{in}(\textit{bob},classroom,\overline{2})\},\end{array}\end{equation}
\begin{equation}\begin{array} l\{\textit{in}(\textit{alice},hall,\overline{0}),\textit{in}(\textit{bob},hall,\overline{0}),\\\hskip 2mm\textit{in}(\textit{alice},classroom,\overline{1}),\textit{in}(\textit{bob},hall,\overline{1}),\\\hskip 2mm\textit{in}(\textit{alice},classroom,\overline{2}),\textit{in}(\textit{bob},classroom,\overline{2})\},\end{array}\end{equation}
 and the private atoms 
 $\textit{in_building}(p,\overline{i})$
 for all p in
$\textit{in_building}(p,\overline{i})$
 for all p in 
 $\{\textit{alice},\textit{bob}\}$
 and all i in
$\{\textit{alice},\textit{bob}\}$
 and all i in 
 $\{0,1,2\}$
. The io-model of
$\{0,1,2\}$
. The io-model of 
 $\Omega_1$
 for
$\Omega_1$
 for 
 $(v,\mathcal{I})$
 consists of the members of
$(v,\mathcal{I})$
 consists of the members of 
 $\mathcal{I}$
 and atoms (13).
$\mathcal{I}$
 and atoms (13).
2.3 Two-sorted formulas and standard interpretations
 The two-sorted signature 
 $\sigma_0$
 includes
$\sigma_0$
 includes
- • the sort general and its subsort integer; 
- • all precomputed terms of mini-gringo as object constants; an object constant is assigned the sort integer iff it is a numeral; 
- • the symbol  $|\,|$
 as a unary function constant; its argument and value have the sort integer; $|\,|$
 as a unary function constant; its argument and value have the sort integer;
- • the symbols  $+$
, $+$
, $-$
 and $-$
 and $\times$
 as binary function constants; their arguments and values have the sort integer; $\times$
 as binary function constants; their arguments and values have the sort integer;
- • predicate symbols  $p/n$
 as n-ary predicate constants; their arguments have the sort general; $p/n$
 as n-ary predicate constants; their arguments have the sort general;
- • symbols (9) as binary predicate constants; their arguments have the sort general.Footnote 1 
 A formula of the form 
 $(p/n)({\bf t})$
 can be written also as
$(p/n)({\bf t})$
 can be written also as 
 $p({\bf t})$
. This convention allows us to view precomputed atoms (Section 2.1.1) as sentences over
$p({\bf t})$
. This convention allows us to view precomputed atoms (Section 2.1.1) as sentences over 
 $\sigma_0$
. Conjunctions of equalities and inequalities can be abbreviated as usual in algebra; for instance,
$\sigma_0$
. Conjunctions of equalities and inequalities can be abbreviated as usual in algebra; for instance, 
 $X=Y<Z$
 stands for
$X=Y<Z$
 stands for 
 $X=Y\land Y<Z$
.
$X=Y\land Y<Z$
.
 An interpretation of the signature 
 $\sigma_0$
 is standard if
$\sigma_0$
 is standard if
- (a) its domain of the sort general is the set of precomputed terms; 
- (b) its domain of the sort integer is the set of numerals; 
- (c) every object constant represents itself; 
- (d) the absolute value symbol and the binary function constants are interpreted as usual in arithmetic; 
- (e) predicate constants (9) are interpreted in accordance with the total order on precomputed terms chosen in the definition of mini-gringo (Section 2.1.1). 
 A standard interpretation will be uniquely determined if we specify the set 
 $\mathcal{J}$
 of precomputed atoms to which it assigns the value true. This interpretation will be denoted by
$\mathcal{J}$
 of precomputed atoms to which it assigns the value true. This interpretation will be denoted by 
 $\mathcal{J}^\uparrow$
.
$\mathcal{J}^\uparrow$
.
 When formulas over 
 $\sigma_0$
 are used in reasoning about io-programs with placeholders, we may need interpretations satisfying a condition different from (c). An interpretation is standard for a set PH of symbolic constants if it satisfies conditions (a), (b), (d), (e) above and the conditions
$\sigma_0$
 are used in reasoning about io-programs with placeholders, we may need interpretations satisfying a condition different from (c). An interpretation is standard for a set PH of symbolic constants if it satisfies conditions (a), (b), (d), (e) above and the conditions
(cʹ) every object constant that belongs to PH represents a precomputed term that does not belong to PH;
(cʹʹ) every object constant that does not belong to PH represents itself.
 An interpretation that is standard for PH will be uniquely determined if we specify (i) the valuation v that maps every element of PH to the precomputed term that it represents, and (ii) the set 
 $\mathcal{J}$
 of precomputed atoms to which it assigns the value true. This interpretation will be denoted by
$\mathcal{J}$
 of precomputed atoms to which it assigns the value true. This interpretation will be denoted by 
 $\mathcal{J}^v$
.
$\mathcal{J}^v$
.
2.4 Representing rules by formulas
 From now on, we assume that every symbol designated as a variable in mini-gringo is among general variables of the signature 
 $\sigma_0$
. The transformation
$\sigma_0$
. The transformation 
 $\tau^*$
, described in this section, converts mini-gringo rules into formulas over
$\tau^*$
, described in this section, converts mini-gringo rules into formulas over 
 $\sigma_0$
.
$\sigma_0$
.
 First we define, for every mini-gringo term t, a formula 
 $\mathit{val}_{t}(V)$
 over the signature
$\mathit{val}_{t}(V)$
 over the signature 
 $\sigma_0$
, where V is a general variable that does not occur in t. That formula expresses, informally speaking, that V is one of the values of t. The definition is recursive:Footnote 2
$\sigma_0$
, where V is a general variable that does not occur in t. That formula expresses, informally speaking, that V is one of the values of t. The definition is recursive:Footnote 2
- • if t is a precomputed term or a variable then  $\mathit{val}_{t}(V)$
 is $\mathit{val}_{t}(V)$
 is $V=t$
, $V=t$
,
- • if t is  $|t_1|$
 then $|t_1|$
 then $\mathit{val}_{t}(V)$
 is $\mathit{val}_{t}(V)$
 is $\exists I(\mathit{val}_{t_1}(I)\land V =|I|)$
, $\exists I(\mathit{val}_{t_1}(I)\land V =|I|)$
,
- • if t is  $t_1\;\textit{op}\;t_2$
, where op is $t_1\;\textit{op}\;t_2$
, where op is $+$
, $+$
, $-$
, or $-$
, or $\times$
 then $\times$
 then $\mathit{val}_{t}(V)$
 is $\mathit{val}_{t}(V)$
 is $$\exists I J (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J) \land V=I\;\textit{op}\;J),$$ $$\exists I J (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J) \land V=I\;\textit{op}\;J),$$
- • if t is  $t_1\,/\,t_2$
 then $t_1\,/\,t_2$
 then $\mathit{val}_{t}(V)$
 is $\mathit{val}_{t}(V)$
 is $$\begin{array} l\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J)\land K\times |J|\leq |I|<(K+\overline{1})\times |J|\\\hskip 1.2cm \land\; ((I\times J \geq \overline{0} \land V=K)\lor(I\times J < \overline{0} \land V=-K))),\end{array}$$ $$\begin{array} l\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J)\land K\times |J|\leq |I|<(K+\overline{1})\times |J|\\\hskip 1.2cm \land\; ((I\times J \geq \overline{0} \land V=K)\lor(I\times J < \overline{0} \land V=-K))),\end{array}$$
- • if t is  $t_1\backslash t_2$
 then $t_1\backslash t_2$
 then $\mathit{val}_{t}(V)$
 is $\mathit{val}_{t}(V)$
 is $$\begin{array} l\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J)\land K\times |J|\leq |I|<(K+\overline{1})\times |J|\\\hskip 1.2cm \land\; ((I\times J \geq \overline{0} \land V=I-K\times J)\lor(I\times J < \overline{0} \land V=I+K\times J))),\end{array}$$ $$\begin{array} l\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J)\land K\times |J|\leq |I|<(K+\overline{1})\times |J|\\\hskip 1.2cm \land\; ((I\times J \geq \overline{0} \land V=I-K\times J)\lor(I\times J < \overline{0} \land V=I+K\times J))),\end{array}$$
- • if t is  $t_1\,..\,t_2$
 then $t_1\,..\,t_2$
 then $\mathit{val}_{t}(V)$
 is where I, J, K are fresh integer variables. $\mathit{val}_{t}(V)$
 is where I, J, K are fresh integer variables. $$\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J) \land I\leq K \leq J \land V=K),$$ $$\exists I J K (\mathit{val}_{t_1}(I) \land \mathit{val}_{t_2}(J) \land I\leq K \leq J \land V=K),$$
 If 
 $\bf t$
 is a tuple
$\bf t$
 is a tuple 
 $t_1,\dots,t_n$
 of mini-gringo terms, and
$t_1,\dots,t_n$
 of mini-gringo terms, and 
 $\bf V$
 is a tuple
$\bf V$
 is a tuple 
 $V_1,\dots,V_n$
 of distinct general variables, then
$V_1,\dots,V_n$
 of distinct general variables, then 
 $\mathit{val}_{\bf t}(\bf V)$
 stands for the conjunction
$\mathit{val}_{\bf t}(\bf V)$
 stands for the conjunction 
 $\mathit{val}_{t_1}(V_1) \land \cdots \land \mathit{val}_{t_n}(V_n)$
.
$\mathit{val}_{t_1}(V_1) \land \cdots \land \mathit{val}_{t_n}(V_n)$
.
 The next step is to define the transformation 
 $\tau^B$
, which converts literals and comparisons into formulas over
$\tau^B$
, which converts literals and comparisons into formulas over 
 $\sigma_0$
. (The superscript B reflects the fact that this translation is close to the meaning of expressions in bodies of rules.) It transforms
$\sigma_0$
. (The superscript B reflects the fact that this translation is close to the meaning of expressions in bodies of rules.) It transforms
- •  $p({\bf t})$
 into $p({\bf t})$
 into $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land p({\bf V}))$
; $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land p({\bf V}))$
;
- •  $\textit{not}\ p({\bf t})$
 into $\textit{not}\ p({\bf t})$
 into $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land \neg p({\bf V}))$
; $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land \neg p({\bf V}))$
;
- •  $\textit{not}\ \textit{not}\ p({\bf t})$
 into $\textit{not}\ \textit{not}\ p({\bf t})$
 into $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land \neg\neg p({\bf V}))$
; $\exists {\bf V}({\mathit{val}_{\bf t}(\bf V)} \land \neg\neg p({\bf V}))$
;
- •  $t_1 \;\mathit{rel}\; t_2$
 into $t_1 \;\mathit{rel}\; t_2$
 into $\exists V_1 V_2 (\mathit{val}_{t_1}(V_1) \land \mathit{val}_{t_2}(V_2) \land V_1\;\mathit{rel}\; V_2)$
. $\exists V_1 V_2 (\mathit{val}_{t_1}(V_1) \land \mathit{val}_{t_2}(V_2) \land V_1\;\mathit{rel}\; V_2)$
.
 If Body is a conjunction 
 $B_1\land B_2\land\cdots$
 of literals and comparisons then
$B_1\land B_2\land\cdots$
 of literals and comparisons then 
 $\tau^B(\textit{Body})$
 stands for the conjunction
$\tau^B(\textit{Body})$
 stands for the conjunction 
 $\tau^B(B_1)\land\tau^B(B_2)\land\cdots$
.
$\tau^B(B_1)\land\tau^B(B_2)\land\cdots$
.
 Now we are ready to define the transformation 
 $\tau^*$
. It converts a basic rule
$\tau^*$
. It converts a basic rule 
 \begin{gather} p({\bf t}) \leftarrow \mathit{Body,} \end{gather}
\begin{gather} p({\bf t}) \leftarrow \mathit{Body,} \end{gather}
 of a program 
 $\Pi$
 into the formula
$\Pi$
 into the formula 
 $$\widetilde{\forall}({\mathit{val}_{\bf t}(\bf V)} \land \tau^B(\mathit{Body}) \rightarrow p({\bf V})),$$
$$\widetilde{\forall}({\mathit{val}_{\bf t}(\bf V)} \land \tau^B(\mathit{Body}) \rightarrow p({\bf V})),$$
 where 
 $\bf V$
 is the list of alphabetically first general variables that do not occur in
$\bf V$
 is the list of alphabetically first general variables that do not occur in 
 $\Pi$
, and
$\Pi$
, and 
 $\widetilde{\forall}$
 denotes universal closure (see Appendix A). A choice rule
$\widetilde{\forall}$
 denotes universal closure (see Appendix A). A choice rule 
 \begin{equation}\{p({\bf t})\} \leftarrow \mathit{Body,}\end{equation}
\begin{equation}\{p({\bf t})\} \leftarrow \mathit{Body,}\end{equation}
is converted intoFootnote 3
 \begin{equation} \widetilde{\forall}({\mathit{val}_{\bf t}(\bf V)} \land \tau^B(\mathit{Body}) \land \neg\neg p({\bf V}) \rightarrow p({\bf V})), \end{equation}
\begin{equation} \widetilde{\forall}({\mathit{val}_{\bf t}(\bf V)} \land \tau^B(\mathit{Body}) \land \neg\neg p({\bf V}) \rightarrow p({\bf V})), \end{equation}
 and a constraint 
 $\leftarrow\mathit{Body}$
 becomes
$\leftarrow\mathit{Body}$
 becomes 
 $\widetilde{\forall}(\tau^B(\mathit{Body})\to\bot)$
.
$\widetilde{\forall}(\tau^B(\mathit{Body})\to\bot)$
.
 By 
 $\tau^*\Pi$
 we denote the set of sentences
$\tau^*\Pi$
 we denote the set of sentences 
 $\tau^* R$
 for all rules R of
$\tau^* R$
 for all rules R of 
 $\Pi$
.
$\Pi$
.
 The transformation 
 $\tau^*$
 can be used in place of the transformation
$\tau^*$
 can be used in place of the transformation 
 $\tau$
 (Section 2.1.2) to describe the stable models of a mini-gringo program, as shown by the theorem below. Its statement refers to stable models of many-sorted theories (Appendix B) for the case when the underlying signature is
$\tau$
 (Section 2.1.2) to describe the stable models of a mini-gringo program, as shown by the theorem below. Its statement refers to stable models of many-sorted theories (Appendix B) for the case when the underlying signature is 
 $\sigma_0$
, and all comparison symbols are classified as extensional. Its proof is given in Section 8.
$\sigma_0$
, and all comparison symbols are classified as extensional. Its proof is given in Section 8.
Theorem 1 A set 
 $\mathcal{J}$
 of precomputed atoms is a stable model of a mini-gringo program
$\mathcal{J}$
 of precomputed atoms is a stable model of a mini-gringo program 
 $\Pi$
 iff
$\Pi$
 iff 
 $\mathcal{J}^\uparrow$
 is a stable model of
$\mathcal{J}^\uparrow$
 is a stable model of 
 $\tau^*\Pi$
.
$\tau^*\Pi$
.
3 Completion
 This section describes the process of constructing the completion of an io-program. This construction involves the formulas 
 $\tau^*R$
 for the rules R of the program, and it exploits the special syntactic form of these formulas, as discussed below.
$\tau^*R$
 for the rules R of the program, and it exploits the special syntactic form of these formulas, as discussed below.
3.1 Completable sets
 Consider a many-sorted signature 
 $\sigma$
 (see Appendix A) with its predicate constants partitioned into intensional symbols and extensional symbols, so that the set of intensional symbols is finite. A sentence over
$\sigma$
 (see Appendix A) with its predicate constants partitioned into intensional symbols and extensional symbols, so that the set of intensional symbols is finite. A sentence over 
 $\sigma$
 is completable if it has the form
$\sigma$
 is completable if it has the form 
 \begin{equation}\widetilde{\forall} (F\to G),\end{equation}
\begin{equation}\widetilde{\forall} (F\to G),\end{equation}
 where G either contains no intensional symbols or has the form 
 $p({\bf V})$
, where p is an intensional symbol with argument sorts
$p({\bf V})$
, where p is an intensional symbol with argument sorts 
 $s_1,\dots,s_n$
, and
$s_1,\dots,s_n$
, and 
 $\bf V$
 is a tuple of pairwise distinct variables of these sorts. A finite set
$\bf V$
 is a tuple of pairwise distinct variables of these sorts. A finite set 
 $\Gamma$
 of sentences is completable if
$\Gamma$
 of sentences is completable if
- • every sentence in  $\Gamma$
 is completable, and $\Gamma$
 is completable, and
- • for any two sentences  $\widetilde{\forall} (F_1\to G_1)$
, $\widetilde{\forall} (F_1\to G_1)$
, $\widetilde{\forall} (F_2\to G_2)$
 in $\widetilde{\forall} (F_2\to G_2)$
 in $\Gamma$
 such that $\Gamma$
 such that $G_1$
 and $G_1$
 and $G_2$
 contain the same intensional symbol, $G_2$
 contain the same intensional symbol, $G_1=G_2$
. $G_1=G_2$
.
 It is easy to see that for any mini-gringo program 
 $\Pi$
, the set
$\Pi$
, the set 
 $\tau^*\Pi$
 is completable.
$\tau^*\Pi$
 is completable.
 The definition of an intensional symbol p in a completable set 
 $\Gamma$
 is the set of members (17) of
$\Gamma$
 is the set of members (17) of 
 $\Gamma$
 such that p occurs in G. A first-order constraint is a completable sentence (17) such that G does not contain intensional symbols. Thus
$\Gamma$
 such that p occurs in G. A first-order constraint is a completable sentence (17) such that G does not contain intensional symbols. Thus 
 $\Gamma$
 is the union of the definitions of intensional symbols and a set of first-order constraints.
$\Gamma$
 is the union of the definitions of intensional symbols and a set of first-order constraints.
 If the definition of p in 
 $\Gamma$
 consists of the sentences
$\Gamma$
 consists of the sentences 
 $\widetilde{\forall}(F_i({\bf V})\to p({\bf V}))$
 then the completed definition of p in
$\widetilde{\forall}(F_i({\bf V})\to p({\bf V}))$
 then the completed definition of p in 
 $\Gamma$
 is the sentence
$\Gamma$
 is the sentence 
 $$\forall {\bf V} \left (p({\bf V}) \leftrightarrow \bigvee_i \exists {\bf U}_i\,F_i({\bf V}) \right ),$$
$$\forall {\bf V} \left (p({\bf V}) \leftrightarrow \bigvee_i \exists {\bf U}_i\,F_i({\bf V}) \right ),$$
 where 
 ${\bf U}_i$
 is the list of free variables of
${\bf U}_i$
 is the list of free variables of 
 $F_i({\bf V})$
 that do not belong to
$F_i({\bf V})$
 that do not belong to 
 $\bf V$
.
$\bf V$
.
 The completion 
 $\mathrm{COMP}[\Gamma]$
 of a completable set
$\mathrm{COMP}[\Gamma]$
 of a completable set 
 $\Gamma$
 is the conjunction of the completed definitions of all intensional symbols of
$\Gamma$
 is the conjunction of the completed definitions of all intensional symbols of 
 $\sigma$
 in
$\sigma$
 in 
 $\Gamma$
 and the constraints of
$\Gamma$
 and the constraints of 
 $\Gamma$
.
$\Gamma$
.
3.2 Completion of a program with input and output
 The completion of an io-program (10) is the second-order sentenceFootnote 4 
 $\exists P_1 \cdots P_l\,C$
, where C is obtained from the sentence
$\exists P_1 \cdots P_l\,C$
, where C is obtained from the sentence 
 $\mathrm{COMP}[\tau^*\Pi]$
 by replacing all private symbols
$\mathrm{COMP}[\tau^*\Pi]$
 by replacing all private symbols 
 $p_1/n_1,\dots,p_l/n_l$
 with distinct predicate variables
$p_1/n_1,\dots,p_l/n_l$
 with distinct predicate variables 
 $P_1,\dots,P_l$
. The completion of
$P_1,\dots,P_l$
. The completion of 
 $\Omega$
 will be denoted by
$\Omega$
 will be denoted by 
 $\mathrm{COMP}[\Omega]$
.Footnote 5 In building
$\mathrm{COMP}[\Omega]$
.Footnote 5 In building 
 $\mathrm{COMP}[\Omega]$
, we classify as extensional all comparison and input symbols. All output and private symbols are intensional.
$\mathrm{COMP}[\Omega]$
, we classify as extensional all comparison and input symbols. All output and private symbols are intensional.
Consider, for example, the io-program with the rules
 \begin{equation}\begin{array} lp(a),\\p(b),\\q(X,Y) \leftarrow p(X) \land p(Y),\end{array}\end{equation}
\begin{equation}\begin{array} lp(a),\\p(b),\\q(X,Y) \leftarrow p(X) \land p(Y),\end{array}\end{equation}
 without input symbols and with the output symbol 
 $q/2$
. The translation
$q/2$
. The translation 
 $\tau^*$
 transforms these rules into the formulas
$\tau^*$
 transforms these rules into the formulas 
 \begin{gather} \newcommand{\shorteq}{\hspace{-2pt}=\hspace{-2pt}} \begin{aligned}[c] &\forall V_1(V_1=a \to p(V_1)),\\ &\forall V_1(V_1=b \to p(V_1)),\\ &\forall XYV_1V_2(V_1 \shorteq X \land V_2 \shorteq Y \land \exists V(V \shorteq X \land p(V)) \land\exists V(V \shorteq Y \land p(V))\to q(V_1,V_2)). \end{aligned} \end{gather}
\begin{gather} \newcommand{\shorteq}{\hspace{-2pt}=\hspace{-2pt}} \begin{aligned}[c] &\forall V_1(V_1=a \to p(V_1)),\\ &\forall V_1(V_1=b \to p(V_1)),\\ &\forall XYV_1V_2(V_1 \shorteq X \land V_2 \shorteq Y \land \exists V(V \shorteq X \land p(V)) \land\exists V(V \shorteq Y \land p(V))\to q(V_1,V_2)). \end{aligned} \end{gather}
 The completed definition of 
 $p/1$
 in (19) is
$p/1$
 in (19) is 
 $$\forall V_1 (p(V_1) \leftrightarrow V_1=a \lor V_1=b),$$
$$\forall V_1 (p(V_1) \leftrightarrow V_1=a \lor V_1=b),$$
 and the completed definition of 
 $q/2$
 is
$q/2$
 is 
 $$\begin{array} l\forall V_1V_2(q(V_1,V_2)\, \leftrightarrow\\\qquad\quad\qquad\exists XY(V_1=X \land V_2=Y \land \exists V(V=X \land p(V)) \land\exists V(V=Y\land p(V)))).\end{array}$$
$$\begin{array} l\forall V_1V_2(q(V_1,V_2)\, \leftrightarrow\\\qquad\quad\qquad\exists XY(V_1=X \land V_2=Y \land \exists V(V=X \land p(V)) \land\exists V(V=Y\land p(V)))).\end{array}$$
The completion of the program is
 \begin{equation}\begin{array} l\!\!\!\exists P(\forall V_1(P(V_1) \leftrightarrow V_1=a \lor V_1=b)\,\land\\\quad\;\forall V_1V_2(q(V_1,V_2)\, \leftrightarrow\\\qquad\;\;\;\exists XY(V_1=X \land V_2=Y \land \exists V(V=X \land P(V)) \land\exists V(V=Y\land P(V))))).\end{array}\end{equation}
\begin{equation}\begin{array} l\!\!\!\exists P(\forall V_1(P(V_1) \leftrightarrow V_1=a \lor V_1=b)\,\land\\\quad\;\forall V_1V_2(q(V_1,V_2)\, \leftrightarrow\\\qquad\;\;\;\exists XY(V_1=X \land V_2=Y \land \exists V(V=X \land P(V)) \land\exists V(V=Y\land P(V))))).\end{array}\end{equation}
Formula (20) can be equivalently rewritten as
 $$\exists P(\forall V_1(P(V_1) \leftrightarrow V_1=a \lor V_1=b)\land\forall V_1V_2(q(V_1,V_2) \leftrightarrow P(V_1) \land P(V_2))).$$
$$\exists P(\forall V_1(P(V_1) \leftrightarrow V_1=a \lor V_1=b)\land\forall V_1V_2(q(V_1,V_2) \leftrightarrow P(V_1) \land P(V_2))).$$
Second-order quantifiers in completion formulas can often be eliminated. For instance, formula (20) is equivalent to the first-order formula
 $$\forall V_1V_2(q(V_1,V_2) \leftrightarrow (V_1=a \lor V_1=b)\land(V_2=a \lor V_2=b)).$$
$$\forall V_1V_2(q(V_1,V_2) \leftrightarrow (V_1=a \lor V_1=b)\land(V_2=a \lor V_2=b)).$$
3.3 Review: Tight programs
 We are interested in cases when the sentence 
 $\mathrm{COMP}[\Omega]$
 can be viewed as a description of the io-models of
$\mathrm{COMP}[\Omega]$
 can be viewed as a description of the io-models of 
 $\Omega$
. This is a review of one result of this kind.
$\Omega$
. This is a review of one result of this kind.
 The positive predicate dependency graph of a mini-gringo program 
 $\Pi$
 is the directed graph defined as follows. Its vertices are the predicate symbols
$\Pi$
 is the directed graph defined as follows. Its vertices are the predicate symbols 
 $p/n$
 that occur in
$p/n$
 that occur in 
 $\Pi$
. It has an edge from
$\Pi$
. It has an edge from 
 $p/n$
 to
$p/n$
 to 
 $p'/n'$
 iff
$p'/n'$
 iff 
 $p/n$
 occurs in the head of a rule R of
$p/n$
 occurs in the head of a rule R of 
 $\Pi$
 such that
$\Pi$
 such that 
 $p'/n'$
 occurs in an atom that is a conjunctive term of the body of R.
$p'/n'$
 occurs in an atom that is a conjunctive term of the body of R.
 A mini-gringo program is tight if its positive predicate dependency graph is acyclic. For example, the positive predicate dependency graph of program (18) has a single edge, from 
 $q/2$
 to
$q/2$
 to 
 $p/1$
; this program is tight. The positive predicate dependency graph of program (3)–(8) includes a self-loop at
$p/1$
; this program is tight. The positive predicate dependency graph of program (3)–(8) includes a self-loop at 
 $\textit{in}/3$
; this program is not tight.
$\textit{in}/3$
; this program is not tight.
 Let 
 $\Omega$
 be an io-program
$\Omega$
 be an io-program 
 $(\Pi,\textit{PH},\textit{In},\textit{Out})$
, and let
$(\Pi,\textit{PH},\textit{In},\textit{Out})$
, and let 
 $\mathcal{P}$
 be a set of precomputed public atoms that do not contain placeholders of
$\mathcal{P}$
 be a set of precomputed public atoms that do not contain placeholders of 
 $\Omega$
. Under the assumption that
$\Omega$
. Under the assumption that 
 $\Pi$
 is tight,
$\Pi$
 is tight, 
 $\mathcal{P}$
 is an io-model of
$\mathcal{P}$
 is an io-model of 
 $\Omega$
 for an input
$\Omega$
 for an input 
 $(v,\mathcal{I})$
 iff
$(v,\mathcal{I})$
 iff 
 $\mathcal{P}^v$
 satisfies
$\mathcal{P}^v$
 satisfies 
 $\mathrm{COMP}[\Omega]$
 and
$\mathrm{COMP}[\Omega]$
 and 
 $\mathcal{P}^{in} = \mathcal{I}$
 (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Theorem 2).
$\mathcal{P}^{in} = \mathcal{I}$
 (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Theorem 2).
4 Locally tight programs
 For any tuple 
 $t_1,\dots,t_n$
 of ground terms,
$t_1,\dots,t_n$
 of ground terms, 
 $[t_1,\dots,t_n]$
 stands for the set of tuples
$[t_1,\dots,t_n]$
 stands for the set of tuples 
 $r_1,\dots,r_n$
 of precomputed terms such that
$r_1,\dots,r_n$
 of precomputed terms such that 
 $r_1\in[t_1],\dots,r_n\in[t_n]$
.
$r_1\in[t_1],\dots,r_n\in[t_n]$
.
 The positive dependency graph of an io-program 
 $\Omega$
 for an input
$\Omega$
 for an input 
 $(v,\mathcal{I})$
 is the directed graph defined as follows. Its vertices are the ground atoms
$(v,\mathcal{I})$
 is the directed graph defined as follows. Its vertices are the ground atoms 
 $p(r_1,\dots,r_n)$
 such that
$p(r_1,\dots,r_n)$
 such that 
 $p/n$
 is an output symbol or a private symbol of
$p/n$
 is an output symbol or a private symbol of 
 $\Omega$
, and each
$\Omega$
, and each 
 $r_i$
 is a precomputed term different from the placeholders of
$r_i$
 is a precomputed term different from the placeholders of 
 $\Omega$
. It has an edge from
$\Omega$
. It has an edge from 
 $p({\bf r})$
 to
$p({\bf r})$
 to 
 $p'({\bf r}')$
 iff there exists a ground instance R of one of the rules of
$p'({\bf r}')$
 iff there exists a ground instance R of one of the rules of 
 $v(\Pi)$
 such that
$v(\Pi)$
 such that
- (a) the head of R has the form  $p({\bf t})$
 or $p({\bf t})$
 or $\{p({\bf t})\}$
, where t is a tuple of terms such that $\{p({\bf t})\}$
, where t is a tuple of terms such that ${\bf r}\in[{\bf t}]$
; ${\bf r}\in[{\bf t}]$
;
- (b) the body of R has a conjunctive term of the form  $p'({\bf t})$
, where t is a tuple of terms such that $p'({\bf t})$
, where t is a tuple of terms such that ${\bf r}'\in[{\bf t}]$
; ${\bf r}'\in[{\bf t}]$
;
- (c) for every conjunctive term of the body of R that contains an input symbol of  $\Omega$
 and has the form $\Omega$
 and has the form $q({\bf t})$
 or $q({\bf t})$
 or $\textit{not}\ \textit{not}\ q({\bf t})$
, the set $\textit{not}\ \textit{not}\ q({\bf t})$
, the set $[{\bf t}]$
 contains a tuple $[{\bf t}]$
 contains a tuple $\bf r$
 such that $\bf r$
 such that $q({\bf r})\in\mathcal{I}$
; $q({\bf r})\in\mathcal{I}$
;
- (d) for every conjunctive term of the body of R that contains an input symbol of  $\Omega$
 and has the form $\Omega$
 and has the form $\textit{not}\ q({\bf t})$
, the set $\textit{not}\ q({\bf t})$
, the set $[{\bf t}]$
 contains a tuple $[{\bf t}]$
 contains a tuple $\bf r$
 such that $\bf r$
 such that $q({\bf r})\not\in\mathcal{I}$
; $q({\bf r})\not\in\mathcal{I}$
;
- (e) for every comparison  ${t_1 \prec t_2}$
 in the body of R, there exist terms ${t_1 \prec t_2}$
 in the body of R, there exist terms $r_1$
, $r_1$
, $r_2$
 such that $r_2$
 such that $r_1\in[t_1]$
, $r_1\in[t_1]$
, $r_2\in[t_2]$
, and the relation $r_2\in[t_2]$
, and the relation $\prec$
 holds for the pair $\prec$
 holds for the pair ${(r_1,r_2)}$
. ${(r_1,r_2)}$
.
 Recall that an infinite walk in a directed graph is an infinite sequence of edges which joins a sequence of vertices. If the positive dependency graph of 
 $\Omega$
 for an input
$\Omega$
 for an input 
 $(v,\mathcal{I})$
 has no infinite walks, then we say that
$(v,\mathcal{I})$
 has no infinite walks, then we say that 
 $\Omega$
 is locally tight on that input.
$\Omega$
 is locally tight on that input.
 Consider, for example, the positive dependency graph of the io-program 
 $\Omega_1$
 (Section 2.2). Its vertices for an input
$\Omega_1$
 (Section 2.2). Its vertices for an input 
 $(v,\mathcal{I})$
 are atoms
$(v,\mathcal{I})$
 are atoms 
 $\textit{in}(p,r,t)$
 and
$\textit{in}(p,r,t)$
 and 
 $\textit{in_building}(p,t)$
, where p, r, t are precomputed terms different from h. The only rules of
$\textit{in_building}(p,t)$
, where p, r, t are precomputed terms different from h. The only rules of 
 $\Omega_1$
 that contribute edges to the graph are (5) and (7), because all predicate symbols in the bodies of (3) and (4) are input symbols, and rules (6) and (8) are constraints. If R is (5) then v(R) is the rule
$\Omega_1$
 that contribute edges to the graph are (5) and (7), because all predicate symbols in the bodies of (3) and (4) are input symbols, and rules (6) and (8) are constraints. If R is (5) then v(R) is the rule 

An instance
 $$\{\textit{in}(p,r,t+\overline{1})\} \leftarrow \textit{in}(p,r,t) \land t = \overline{0}\,..\,v(h)\!-\!\overline{1},$$
$$\{\textit{in}(p,r,t+\overline{1})\} \leftarrow \textit{in}(p,r,t) \land t = \overline{0}\,..\,v(h)\!-\!\overline{1},$$
 of this rule contributes an edge if and only if v(h) is a numeral 
 $\overline{n}$
, t is a numeral
$\overline{n}$
, t is a numeral 
 $\overline{i}$
, and
$\overline{i}$
, and 
 $0\leq i<n$
. If R is (7) then
$0\leq i<n$
. If R is (7) then 
 $v(R)=R$
, and an instance
$v(R)=R$
, and an instance 
 $$\textit{in_building}(p,t) \leftarrow \textit{in}(p,r,t),$$
$$\textit{in_building}(p,t) \leftarrow \textit{in}(p,r,t),$$
of v(R) contributes the edge
 \begin{equation}\textit{in_building}(p,t) \longrightarrow \textit{in}(p,r,t).\end{equation}
\begin{equation}\textit{in_building}(p,t) \longrightarrow \textit{in}(p,r,t).\end{equation}
 Consequently the edges of the positive dependency graph of 
 $\Omega_1$
 are (21) and
$\Omega_1$
 are (21) and 
 $$\textit{in}(p,r,\overline{i+1}) \longrightarrow \textit{in}(p,r,\overline{i}),$$
$$\textit{in}(p,r,\overline{i+1}) \longrightarrow \textit{in}(p,r,\overline{i}),$$
 if 
 $v(h)=\overline{n}$
 and
$v(h)=\overline{n}$
 and 
 $0\leq i <n$
. It is clear that this graph has no infinite walks. Consequently
$0\leq i <n$
. It is clear that this graph has no infinite walks. Consequently 
 $\Omega_1$
 is locally tight on all inputs.
$\Omega_1$
 is locally tight on all inputs.
Proposition 1 If a mini-gringo program 
 $\Pi$
 is tight then any io-program of the form
$\Pi$
 is tight then any io-program of the form 
 $(\Pi,\textit{PH},\textit{In},\textit{Out})$
 is locally tight for all inputs.
$(\Pi,\textit{PH},\textit{In},\textit{Out})$
 is locally tight for all inputs.
Proof Assume that 
 $\Pi$
 is tight, but the positive dependency graph of
$\Pi$
 is tight, but the positive dependency graph of 
 $(\Pi,\textit{PH},\textit{In},\textit{Out})$
 for some input has an infinite walk. If that graph has an edge from
$(\Pi,\textit{PH},\textit{In},\textit{Out})$
 for some input has an infinite walk. If that graph has an edge from 
 $p(r_1,\dots,r_n)$
 to
$p(r_1,\dots,r_n)$
 to 
 $p'(r'_1,\dots,r'_{n'})$
 then the positive predicate dependency graph of
$p'(r'_1,\dots,r'_{n'})$
 then the positive predicate dependency graph of 
 $\Pi$
 has an edge from
$\Pi$
 has an edge from 
 $p/n$
 to
$p/n$
 to 
 $p'/n'$
. Consequently this graph has an infinite walk as well. But that is impossible, because this graph is finite and acyclic.
$p'/n'$
. Consequently this graph has an infinite walk as well. But that is impossible, because this graph is finite and acyclic.
 The example of program 
 $\Omega_1$
 shows that the converse of Proposition 1 does not hold.
$\Omega_1$
 shows that the converse of Proposition 1 does not hold.
 The theorem below generalizes the property of tight programs reviewed at the end of Section 3.3. For any formula F over 
 $\sigma_0$
 and any valuation v, v(F) stands for the formula obtained from F by replacing every occurrence of every constant c in the domain of v by v(c). The proof of the following theorem is given in Section 9.
$\sigma_0$
 and any valuation v, v(F) stands for the formula obtained from F by replacing every occurrence of every constant c in the domain of v by v(c). The proof of the following theorem is given in Section 9.
Theorem 2 For any io-program 
 $\Omega$
, any set
$\Omega$
, any set 
 $\mathcal{P}$
 of precomputed public atoms that do not contain placeholders of
$\mathcal{P}$
 of precomputed public atoms that do not contain placeholders of 
 $\Omega$
, and any input
$\Omega$
, and any input 
 $(v,\mathcal{I})$
 for which
$(v,\mathcal{I})$
 for which 
 $\Omega$
 is locally tight, the following conditions are equivalent:
$\Omega$
 is locally tight, the following conditions are equivalent:
- (a)  $\mathcal{P}$
 is an io-model of $\mathcal{P}$
 is an io-model of $\Omega$
 for $\Omega$
 for $(v,\mathcal{I})$
, $(v,\mathcal{I})$
,
- (b)  $\mathcal{P}^\uparrow$
 satisfies $\mathcal{P}^\uparrow$
 satisfies $v(\mathrm{COMP}[\Omega])$
 and $v(\mathrm{COMP}[\Omega])$
 and $\mathcal{P}^{in} = \mathcal{I}$
, $\mathcal{P}^{in} = \mathcal{I}$
,
- (c)  $\mathcal{P}^v$
 satisfies $\mathcal{P}^v$
 satisfies $\mathrm{COMP}[\Omega]$
 and $\mathrm{COMP}[\Omega]$
 and $\mathcal{P}^{in} = \mathcal{I}$
. $\mathcal{P}^{in} = \mathcal{I}$
.
 Take, for instance, the io-program 
 $\Omega_1$
 and the input
$\Omega_1$
 and the input 
 $(v,\mathcal{I})$
 defined by conditions (12). We observed in Section 2.2 that the set
$(v,\mathcal{I})$
 defined by conditions (12). We observed in Section 2.2 that the set 
 $\mathcal{P}$
 obtained from
$\mathcal{P}$
 obtained from 
 $\mathcal{I}$
 by adding atoms (13) is an io-model of
$\mathcal{I}$
 by adding atoms (13) is an io-model of 
 $\Omega_1$
 for
$\Omega_1$
 for 
 $(v,\mathcal{I})$
. According to Theorem 2, this observation is equivalent to the claim that the corresponding interpretation
$(v,\mathcal{I})$
. According to Theorem 2, this observation is equivalent to the claim that the corresponding interpretation 
 $\mathcal{P}^\uparrow$
 satisfies the sentence obtained from
$\mathcal{P}^\uparrow$
 satisfies the sentence obtained from 
 $\mathrm{COMP}[\Omega_1]$
 by substituting
$\mathrm{COMP}[\Omega_1]$
 by substituting 
 $\overline{2}$
 for the placeholder h.
$\overline{2}$
 for the placeholder h.
5 Equivalence of io-programs
 We begin with an example. Consider the io-program 
 $\Omega_2$
, obtained from
$\Omega_2$
, obtained from 
 $\Omega_1$
 by replacing inertia rule (5) with the pair of rules
$\Omega_1$
 by replacing inertia rule (5) with the pair of rules 
 \begin{equation}\textit{go}(P,T) \leftarrow \textit{goto}(P,R,T),\end{equation}
\begin{equation}\textit{go}(P,T) \leftarrow \textit{goto}(P,R,T),\end{equation}
 \begin{equation}\textit{in}(P,R,T+1) \leftarrow \textit{in}(P,R,T) \land \textit{not}\ \textit{go}(P,T) \land T = 0\,..\,h- 1. \end{equation}
\begin{equation}\textit{in}(P,R,T+1) \leftarrow \textit{in}(P,R,T) \land \textit{not}\ \textit{go}(P,T) \land T = 0\,..\,h- 1. \end{equation}
 Here 
 $\textit{go}/2$
 is a new private symbol. These rules express commonsense inertia in a different way, using the fact that goto actions are the only possible causes of change in the location of a person. Programs
$\textit{go}/2$
 is a new private symbol. These rules express commonsense inertia in a different way, using the fact that goto actions are the only possible causes of change in the location of a person. Programs 
 $\Omega_1$
 and
$\Omega_1$
 and 
 $\Omega_2$
 describe the same dynamic system using two different approaches to encoding inertia.
$\Omega_2$
 describe the same dynamic system using two different approaches to encoding inertia.
Are these programs equivalent, in some sense? The idea of equivalence with respect to a user guide (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023) allows us to make this question precise. We present the details below.
 About two io-programs we say that they are comparable to each other if they have the same placeholders, the same input symbols, and the same output symbols. For example, 
 $\Omega_1$
 and
$\Omega_1$
 and 
 $\Omega_2$
 are comparable. Any two comparable programs have the same inputs, because the definition of an input for
$\Omega_2$
 are comparable. Any two comparable programs have the same inputs, because the definition of an input for 
 $\Omega$
 (Section 2.2) refers to only two components of
$\Omega$
 (Section 2.2) refers to only two components of 
 $\Omega$
 – to its placeholders and its input symbols.
$\Omega$
 – to its placeholders and its input symbols.
 We will define when comparable io-programs 
 $\Omega$
,
$\Omega$
, 
 $\Omega'$
 are equivalent to each other on a subset Dom of their inputs. Sets of inputs will be called domains. We need domains to express the idea that two io-programs can be equivalent even if they exhibit different behaviors on some inputs that we consider irrelevant. In an input for
$\Omega'$
 are equivalent to each other on a subset Dom of their inputs. Sets of inputs will be called domains. We need domains to express the idea that two io-programs can be equivalent even if they exhibit different behaviors on some inputs that we consider irrelevant. In an input for 
 $\Omega_1$
 or
$\Omega_1$
 or 
 $\Omega_2$
, for example, the first argument of each of the predicate symbols
$\Omega_2$
, for example, the first argument of each of the predicate symbols 
 $\textit{in}_0/2$
,
$\textit{in}_0/2$
, 
 $\textit{goto}/3$
 is expected to be a person; we are not interested in inputs that contain
$\textit{goto}/3$
 is expected to be a person; we are not interested in inputs that contain 
 $\textit{in}_0(\textit{alice},\textit{hall})$
 but do not contain
$\textit{in}_0(\textit{alice},\textit{hall})$
 but do not contain 
 $\textit{person}(\textit{alice})$
.
$\textit{person}(\textit{alice})$
.
 Domains are infinite sets, but there is a natural way to represent some domains by finite expressions. An assumption for an io-program 
 $\Omega$
 is a sentence over
$\Omega$
 is a sentence over 
 $\sigma_0$
 such that every predicate symbol
$\sigma_0$
 such that every predicate symbol 
 $p/n$
 occurring in it is an input symbol of
$p/n$
 occurring in it is an input symbol of 
 $\Omega$
. The domain defined by an assumption A is the set of all inputs
$\Omega$
. The domain defined by an assumption A is the set of all inputs 
 $(v,\mathcal{I})$
 such that the interpretation
$(v,\mathcal{I})$
 such that the interpretation 
 $\mathcal{I}^v$
 satisfies A. For example, the assumption
$\mathcal{I}^v$
 satisfies A. For example, the assumption 
 \begin{equation}\forall P R (\textit{in}_0(P,R) \to \textit{person}(P)),\end{equation}
\begin{equation}\forall P R (\textit{in}_0(P,R) \to \textit{person}(P)),\end{equation}
 where P and R are general variables, defines the set 
 $\mathcal{I}$
 of all inputs for
$\mathcal{I}$
 of all inputs for 
 $\Omega_1$
 such that
$\Omega_1$
 such that 
 $\textit{person}(p)\in\mathcal{I}$
 whenever
$\textit{person}(p)\in\mathcal{I}$
 whenever 
 $\textit{in}_0(p,r)\in\mathcal{I}$
.
$\textit{in}_0(p,r)\in\mathcal{I}$
.
 About comparable io-programs 
 $\Omega$
,
$\Omega$
, 
 $\Omega'$
 we say that they are equivalent on a domain Dom if, for every input
$\Omega'$
 we say that they are equivalent on a domain Dom if, for every input 
 $(v,\mathcal{I})$
 from Dom,
$(v,\mathcal{I})$
 from Dom, 
 $\Omega$
 and
$\Omega$
 and 
 $\Omega'$
 have the same io-models for that input.
$\Omega'$
 have the same io-models for that input.
anthem-p2p (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023) is a proof assistant designed for verifying equivalence of io-programs in the sense of this definition. It uses the following terminology. A user guide is a quadruple
 \begin{equation}(\textit{PH},\textit{In},\textit{Out},\textit{Dom}),\end{equation}
\begin{equation}(\textit{PH},\textit{In},\textit{Out},\textit{Dom}),\end{equation}
 where PH, In and Out are as in the definition of an io-program (Section 2.2), and Dom is a domain. The assertion that io-programs 
 $(\Pi,\textit{PH},\textit{In},\textit{Out})$
 and
$(\Pi,\textit{PH},\textit{In},\textit{Out})$
 and 
 $(\Pi',\textit{PH},\textit{In},\textit{Out})$
 are equivalent on a domain Dom can be expressed by saying that
$(\Pi',\textit{PH},\textit{In},\textit{Out})$
 are equivalent on a domain Dom can be expressed by saying that 
 $\Pi$
 and
$\Pi$
 and 
 $\Pi'$
 are equivalent with respect to user guide (25).Footnote 6
$\Pi'$
 are equivalent with respect to user guide (25).Footnote 6
We can say, for example, that replacing rule (5) in mini-gringo program (3)–(8) with rules (22) is an equivalent transformation for the user guide (25) with PH, In and Out defined by formulas (11), and with Dom defined by the conjunction of assumption (24) and the assumption
 \begin{equation}\forall P R\, T(\textit{goto}(P,R,T) \to \textit{person}(P)).\end{equation}
\begin{equation}\forall P R\, T(\textit{goto}(P,R,T) \to \textit{person}(P)).\end{equation}
Theorem 3 below shows that using the anthem-p2p algorithm for verifying equivalence of io-programs can be justified under a local tightness condition. If an io-program is locally tight for all inputs satisfying an assumption A then we say that it is locally tight under the assumption A. If two comparable io-programs are equivalent on the domain defined by an assumption A then we say that they are equivalent under the assumption A. The proof of the following theorem is given in Section 10.
Theorem 3 Let 
 $\Omega$
,
$\Omega$
, 
 $\Omega'$
 be comparable io-programs with placeholders PH that are locally tight under an assumption A. Programs
$\Omega'$
 be comparable io-programs with placeholders PH that are locally tight under an assumption A. Programs 
 $\Omega$
,
$\Omega$
, 
 $\Omega'$
 are equivalent to each other under the assumption A iff the sentence
$\Omega'$
 are equivalent to each other under the assumption A iff the sentence 
 \begin{equation}A\to(\mathrm{COMP}[\Omega] \leftrightarrow\mathrm{COMP}[\Omega']),\end{equation}
\begin{equation}A\to(\mathrm{COMP}[\Omega] \leftrightarrow\mathrm{COMP}[\Omega']),\end{equation}
is satisfied by all interpretations that are standard for PH.
 From Theorem 3 we can conclude that equivalence between 
 $\Omega$
 and
$\Omega$
 and 
 $\Omega'$
 will be established if formula (27) is derived from a set of axioms that are satisfied by all interpretations that are standard for PH. This is how anthem-p2p operates (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023, Sections 7).
$\Omega'$
 will be established if formula (27) is derived from a set of axioms that are satisfied by all interpretations that are standard for PH. This is how anthem-p2p operates (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023, Sections 7).
 The claim that 
 $\Omega_1$
 is equivalent to
$\Omega_1$
 is equivalent to 
 $\Omega_2$
 assuming (24) and (26) has been verified by anthem-p2p, with the resolution theorem prover vampire (Kovaćs and Voronkov Reference Kovaćs and Voronkov2013) used as the proof engine. We saw in Section 4 that
$\Omega_2$
 assuming (24) and (26) has been verified by anthem-p2p, with the resolution theorem prover vampire (Kovaćs and Voronkov Reference Kovaćs and Voronkov2013) used as the proof engine. We saw in Section 4 that 
 $\Omega_1$
 is locally tight for all inputs. The positive dependency graph of
$\Omega_1$
 is locally tight for all inputs. The positive dependency graph of 
 $\Omega_2$
 has additional edges, from
$\Omega_2$
 has additional edges, from 
 $\textit{go}(p,t)$
 to
$\textit{go}(p,t)$
 to 
 $\textit{goto}(p,r,t)$
. It is clear that this graph has no infinite walks either, so that
$\textit{goto}(p,r,t)$
. It is clear that this graph has no infinite walks either, so that 
 $\Omega_2$
 is locally tight for all inputs as well.
$\Omega_2$
 is locally tight for all inputs as well.
The process of verifying equivalence in this case was interactive – we helped vampire find a proof by suggesting useful lemmas and an induction axiom, as usual in such experiments (Fandinno et al. Reference Fandinno, Hansen, Lierler, Lifschitz and Temple2023, Section 6; Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020, Figure 5). Induction was needed to prove the lemma
 $$\forall P R\, T(\textit{in}(P,R,T) \to \textit{person}(P)),$$
$$\forall P R\, T(\textit{in}(P,R,T) \to \textit{person}(P)),$$
with (24) used to justify the base case.
6 Main Lemma
The Main Lemma, stated below, relates the completion of a completable set of sentences (Section 3.1) to its stable models (Appendix B).
 As in Section 3.1, 
 $\sigma$
 stands here for a many-sorted signature with its predicate constants partitioned into intensional and extensional. The symbols
$\sigma$
 stands here for a many-sorted signature with its predicate constants partitioned into intensional and extensional. The symbols 
 $\sigma^I$
,
$\sigma^I$
, 
 $\mathbf{d}^*$
, used in this section, are introduced in Appendix A;
$\mathbf{d}^*$
, used in this section, are introduced in Appendix A; 
 $I^\downarrow$
 is defined in Appendix B.
$I^\downarrow$
 is defined in Appendix B.
 We define, for an interpretation I of 
 $\sigma$
 and a sentence F over
$\sigma$
 and a sentence F over 
 $\sigma^I$
, the set
$\sigma^I$
, the set 
 $\mathit{Pos}({F},I)$
 of (strictly) positive atoms of F with respect to I. Elements of this set are formulas of the form
$\mathit{Pos}({F},I)$
 of (strictly) positive atoms of F with respect to I. Elements of this set are formulas of the form 
 $p(\mathbf{d}^*)$
. This set is defined recursively, as follows. If F does not contain intensional symbols or is not satisfied by I then
$p(\mathbf{d}^*)$
. This set is defined recursively, as follows. If F does not contain intensional symbols or is not satisfied by I then 
 $\mathit{Pos}({F},I) = \emptyset$
. Otherwise,
$\mathit{Pos}({F},I) = \emptyset$
. Otherwise,
- (i)  $\mathit{Pos}({p(\mathbf{t})},I) = \{p((\mathbf{t}^I)^*)\}$
; $\mathit{Pos}({p(\mathbf{t})},I) = \{p((\mathbf{t}^I)^*)\}$
;
- (ii)  $\mathit{Pos}({F_1 \wedge F_2},I) = \mathit{Pos}({F_1 \vee F_2},I) = \mathit{Pos}({F_1},I) \cup \mathit{Pos}({F_2},I)$
; $\mathit{Pos}({F_1 \wedge F_2},I) = \mathit{Pos}({F_1 \vee F_2},I) = \mathit{Pos}({F_1},I) \cup \mathit{Pos}({F_2},I)$
;
- (iii)  $\mathit{Pos}({F_1 \to F_2},I) = \mathit{Pos}({F_2},I)$
; $\mathit{Pos}({F_1 \to F_2},I) = \mathit{Pos}({F_2},I)$
;
- (iv)  $\mathit{Pos}({\forall X F(X)},I) = \mathit{Pos}({\exists X F(X)},I) = \bigcup_{d\in|I|^s} \mathit{Pos}({F(d^*)},I)$
 if X is a variable of sort s. $\mathit{Pos}({\forall X F(X)},I) = \mathit{Pos}({\exists X F(X)},I) = \bigcup_{d\in|I|^s} \mathit{Pos}({F(d^*)},I)$
 if X is a variable of sort s.
 It is easy to check by induction on F that 
 $\mathit{Pos}({F},I)$
 is a subset of the set
$\mathit{Pos}({F},I)$
 is a subset of the set 
 $I^\downarrow$
.
$I^\downarrow$
.
 An instance of a completable sentence 
 $\widetilde{\forall}(F \to G)$
 over
$\widetilde{\forall}(F \to G)$
 over 
 $\sigma^I$
 is a sentence obtained from
$\sigma^I$
 is a sentence obtained from 
 $F\to G$
 by substituting names
$F\to G$
 by substituting names 
 $d^*$
 for its free variables. For any completable set
$d^*$
 for its free variables. For any completable set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma^I$
, the positive dependency graph
$\sigma^I$
, the positive dependency graph 
 $G^{sp}_{I}(\Gamma)$
 is the directed graph defined as follows. Its vertices are elements of
$G^{sp}_{I}(\Gamma)$
 is the directed graph defined as follows. Its vertices are elements of 
 $I^\downarrow$
. It has an edge from A to B iff, for some instance
$I^\downarrow$
. It has an edge from A to B iff, for some instance 
 $F\to G$
 of a member of
$F\to G$
 of a member of 
 $\Gamma$
,
$\Gamma$
, 
 $A\in\mathit{Pos}({G},I)$
 and
$A\in\mathit{Pos}({G},I)$
 and 
 $B\in\mathit{Pos}({F},I)$
.
$B\in\mathit{Pos}({F},I)$
.
Main Lemma
 For any interpretation I of 
 $\sigma$
 and any completable set
$\sigma$
 and any completable set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma^I$
 such that the graph
$\sigma^I$
 such that the graph 
 $G^{sp}_I(\Gamma)$
 has no infinite walks, I is a stable model of
$G^{sp}_I(\Gamma)$
 has no infinite walks, I is a stable model of 
 $\Gamma$
 iff
$\Gamma$
 iff 
 $I\models\mathrm{COMP}[\Gamma]$
.
$I\models\mathrm{COMP}[\Gamma]$
.
 Consider, for example, the signature consisting of a single sort, the object constants a, b, and the intensional unary predicate constant p. Let 
 $\Gamma$
 be
$\Gamma$
 be 
 $$\{\forall V(V=a\to p(V)),\ \forall V(V=b \land p(V) \to p(V))\},$$
$$\{\forall V(V=a\to p(V)),\ \forall V(V=b \land p(V) \to p(V))\},$$
and let the interpretations I, J be defined by the conditions
 $$\begin{array} c |I|=|J|=\{0,1,\dots\};\ a^I=a^J=0;\ b^I=b^J=1;\\p^I(n)=\textit{true}\hbox{ iff }n=0;\ p^J(n)=\textit{true}\hbox{ iff }n\in\{0,1\}.\end{array}$$
$$\begin{array} c |I|=|J|=\{0,1,\dots\};\ a^I=a^J=0;\ b^I=b^J=1;\\p^I(n)=\textit{true}\hbox{ iff }n=0;\ p^J(n)=\textit{true}\hbox{ iff }n\in\{0,1\}.\end{array}$$
 Instances of the members of 
 $\Gamma$
 are implications of the forms
$\Gamma$
 are implications of the forms 
 $$n^*=a\to p(n^*)\quad\hbox{and}\quad n^*=b \land p(n^*) \to p(n^*),$$
$$n^*=a\to p(n^*)\quad\hbox{and}\quad n^*=b \land p(n^*) \to p(n^*),$$
 (
 $n=0,1,\dots$
). The set
$n=0,1,\dots$
). The set 
 $I^\downarrow$
 of vertices of the graph
$I^\downarrow$
 of vertices of the graph 
 $G^{sp}_I(\Gamma)$
 is
$G^{sp}_I(\Gamma)$
 is 
 $\{p(0^*)\}$
. This graph has no edges, because, for every n,
$\{p(0^*)\}$
. This graph has no edges, because, for every n, 
 $$\mathit{Pos}({n^*=a},I)=\mathit{Pos}({n^*=b \land p(n^*)},I)=\emptyset.$$
$$\mathit{Pos}({n^*=a},I)=\mathit{Pos}({n^*=b \land p(n^*)},I)=\emptyset.$$
 The set 
 $J^\downarrow$
 of vertices of
$J^\downarrow$
 of vertices of 
 $G^{sp}_J(\Gamma)$
 is
$G^{sp}_J(\Gamma)$
 is 
 $\{p(0^*),p(1^*)\}$
. This graph has one edge – the self-loop at
$\{p(0^*),p(1^*)\}$
. This graph has one edge – the self-loop at 
 $p(1^*)$
, because
$p(1^*)$
, because 
 $$\mathit{Pos}({1^*=b \land p(1^*)},J)=\mathit{Pos}({p(1^*)},J) =\{p(1^*)\}.$$
$$\mathit{Pos}({1^*=b \land p(1^*)},J)=\mathit{Pos}({p(1^*)},J) =\{p(1^*)\}.$$
 Consequently the Main Lemma is applicable to I, but not to J. It asserts that I is a stable model of 
 $\Gamma$
 (which is true) iff I satisfies the completion
$\Gamma$
 (which is true) iff I satisfies the completion 
 $$\forall V(p(V)\leftrightarrow V=a\lor(V=b\land p(b)),$$
$$\forall V(p(V)\leftrightarrow V=a\lor(V=b\land p(b)),$$
 of 
 $\Gamma$
 (which is true as well). The interpretation J, on the other hand, satisfies the completion of
$\Gamma$
 (which is true as well). The interpretation J, on the other hand, satisfies the completion of 
 $\Gamma$
, but it is not a stable model.
$\Gamma$
, but it is not a stable model.
The Main Lemma is similar to two results published earlier (Ferraris et al. Reference Ferraris, Lee and Lifschitz2011, Theorem 11; Lee and Meng Reference Lee and Meng2011, Corollary 4). The former refers to dependencies between predicate constants, rather than ground atoms. The latter is applicable to formulas of different syntactic form.
 About an interpretation I of 
 $\sigma$
 we say that it is semi-Herbrand if
$\sigma$
 we say that it is semi-Herbrand if
- • all elements of its domains are object constants of  $\sigma$
, and $\sigma$
, and
- •  $d^I=d$
 for every such element d.Footnote 7 $d^I=d$
 for every such element d.Footnote 7
 For example, every interpretation of 
 $\sigma_0$
 that is standard, or standard for some set PH (Section 2.3), is semi-Herbrand.
$\sigma_0$
 that is standard, or standard for some set PH (Section 2.3), is semi-Herbrand.
 If I is semi-Herbrand then the graph 
 $G^{sp}_I(\Gamma)$
 can be modified by replacing each vertex
$G^{sp}_I(\Gamma)$
 can be modified by replacing each vertex 
 $p({\bf d}^*)$
 by the atom
$p({\bf d}^*)$
 by the atom 
 $p({\bf d})$
 over the signature
$p({\bf d})$
 over the signature 
 $\sigma$
. This modified positive dependency graph is isomorphic to
$\sigma$
. This modified positive dependency graph is isomorphic to 
 $G^{sp}_I(\Gamma)$
 as defined above. It can be defined independently, by replacing clauses (i) and (iv) in the definition of
$G^{sp}_I(\Gamma)$
 as defined above. It can be defined independently, by replacing clauses (i) and (iv) in the definition of 
 $\mathit{Pos}({ },I)F$
 above by
$\mathit{Pos}({ },I)F$
 above by
 (i)ʹ 
 $\mathit{Pos}({p(\mathbf{t})},I) = \{p(\mathbf{t}^I)\}$
;
$\mathit{Pos}({p(\mathbf{t})},I) = \{p(\mathbf{t}^I)\}$
;
 (iv)ʹ 
 $\mathit{Pos}({\forall X F(X)},I) = \mathit{Pos}({\exists X F(X)},I) = \bigcup_{d\in|I|^s} \mathit{Pos}({F(d)},I)$
 if X is a variable of sort s.
$\mathit{Pos}({\forall X F(X)},I) = \mathit{Pos}({\exists X F(X)},I) = \bigcup_{d\in|I|^s} \mathit{Pos}({F(d)},I)$
 if X is a variable of sort s.
7 Proof of the Main Lemma
The Main Lemma expresses a property of the completion operator, and its proof below consists of two parts. We first prove a similar property of pointwise stable models, defined in Appendix B (Lemma 3); then we relate pointwise stable models to completion.
 As in Section 6, 
 $\sigma$
 stands for a many-sorted signature with its predicate constants subdivided into intensional and extensional.
$\sigma$
 stands for a many-sorted signature with its predicate constants subdivided into intensional and extensional.
Lemma 1 For any HT-interpretation 
 $\langle\mathcal{H},I \rangle$
 and any sentence F over
$\langle\mathcal{H},I \rangle$
 and any sentence F over 
 $\sigma^I$
, if
$\sigma^I$
, if 
 $I \models F$
 and
$I \models F$
 and 
 $\mathit{Pos}({F},I)\subseteq \mathcal{H}$
 then
$\mathit{Pos}({F},I)\subseteq \mathcal{H}$
 then 
 $\langle\mathcal{H},I \rangle\models_{ht} F.$
$\langle\mathcal{H},I \rangle\models_{ht} F.$
Proof By induction on the size of F. Case 1: F does not contain intensional symbols. The assertion of the lemma follows from Proposition 3(b) in Appendix B. Case 2: F contains an intensional symbol. Since 
 ${I\models F}$
, the set
${I\models F}$
, the set 
 $\mathit{Pos}({F},I)$
 is determined by the recursive clauses in the definition of
$\mathit{Pos}({F},I)$
 is determined by the recursive clauses in the definition of 
 $\mathit{Pos}$
. Case 2.1: F is
$\mathit{Pos}$
. Case 2.1: F is 
 $p(\mathbf{t})$
, where p is intensional. Then, the assumption
$p(\mathbf{t})$
, where p is intensional. Then, the assumption 
 $\mathit{Pos}({F},I)\subseteq \mathcal{H}$
 and the claim
$\mathit{Pos}({F},I)\subseteq \mathcal{H}$
 and the claim 
 $\langle\mathcal{H},I\rangle\models_{ht} F$
 turn into the condition
$\langle\mathcal{H},I\rangle\models_{ht} F$
 turn into the condition 
 $p((\mathbf{t}^I)^*)\in \mathcal{H}$
. Case 2.2: F is
$p((\mathbf{t}^I)^*)\in \mathcal{H}$
. Case 2.2: F is 
 $F_1\land F_2$
. Then, from the assumption
$F_1\land F_2$
. Then, from the assumption 
 ${I\models F}$
 we conclude that
${I\models F}$
 we conclude that 
 ${I\models F_i}$
 for
${I\models F_i}$
 for 
 $i=1,2$
. On the other hand,
$i=1,2$
. On the other hand, 
 $$\mathit{Pos}({F_i},I)\subseteq\mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
$$\mathit{Pos}({F_i},I)\subseteq\mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
 By the induction hypothesis, it follows that 
 $\langle\mathcal{H},I\rangle\models_{ht} F_i$
, and consequently
$\langle\mathcal{H},I\rangle\models_{ht} F_i$
, and consequently 
 ${\langle\mathcal{H},I\rangle\models_{ht} F}$
. Case 2.3: F is
${\langle\mathcal{H},I\rangle\models_{ht} F}$
. Case 2.3: F is 
 $F_1\lor F_2$
. Similar to Case 2.2. Case 2.4: F is
$F_1\lor F_2$
. Similar to Case 2.2. Case 2.4: F is 
 $F_1\to F_2$
. Since
$F_1\to F_2$
. Since 
 ${I\models F_1\to F_2}$
, we only need to check that
${I\models F_1\to F_2}$
, we only need to check that 
 ${\langle\mathcal{H},I\rangle \not\models_{ht} F_1}$
 or
${\langle\mathcal{H},I\rangle \not\models_{ht} F_1}$
 or 
 ${\langle\mathcal{H},I\rangle\models_{ht} F_2}$
. Case 2.4.1:
${\langle\mathcal{H},I\rangle\models_{ht} F_2}$
. Case 2.4.1: 
 $I\models F_1$
. Since
$I\models F_1$
. Since 
 $I\models F_1\to F_2$
, it follows that
$I\models F_1\to F_2$
, it follows that 
 $I\models F_2$
. On the other hand,
$I\models F_2$
. On the other hand, 
 $$\mathit{Pos}({F_2},I)=\mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
$$\mathit{Pos}({F_2},I)=\mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
 By the induction hypothesis, it follows that 
 $\langle\mathcal{H},I\rangle\models_{ht} F_2$
. Case 2.4.2:
$\langle\mathcal{H},I\rangle\models_{ht} F_2$
. Case 2.4.2: 
 $I\not\models F_1$
. By Proposition 3(a) in Appendix B, it follows that
$I\not\models F_1$
. By Proposition 3(a) in Appendix B, it follows that 
 $\langle\mathcal{H},I\rangle\not\models_{ht} F_1$
. Case 2.5: F is
$\langle\mathcal{H},I\rangle\not\models_{ht} F_1$
. Case 2.5: F is 
 $\forall X\,G(X)$
, where X is a variable of sort s. Then, for every element d of
$\forall X\,G(X)$
, where X is a variable of sort s. Then, for every element d of 
 $|I|^s$
,
$|I|^s$
, 
 $I\models G(d^*)$
 and
$I\models G(d^*)$
 and 
 $$\mathit{Pos}({G(d^*)},I)\subseteq \mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
$$\mathit{Pos}({G(d^*)},I)\subseteq \mathit{Pos}({F},I)\subseteq \mathcal{H}.$$
 By the induction hypothesis, it follows that 
 $\langle\mathcal{H},I\rangle\models_{ht} G(d^*)$
. We can conclude that
$\langle\mathcal{H},I\rangle\models_{ht} G(d^*)$
. We can conclude that 
 $\langle\mathcal{H},I\rangle\models_{ht} \forall X\,G(X)$
. Case 2.6: F is
$\langle\mathcal{H},I\rangle\models_{ht} \forall X\,G(X)$
. Case 2.6: F is 
 $\exists X\,G(X)$
. Similar to Case 2.5.
$\exists X\,G(X)$
. Similar to Case 2.5.
 The definition of 
 $G^{sp}_{I}(\Gamma)$
 in Section 6 is restricted to the case when
$G^{sp}_{I}(\Gamma)$
 in Section 6 is restricted to the case when 
 $\Gamma$
 is a completable set of sentences over
$\Gamma$
 is a completable set of sentences over 
 $\sigma^I$
. It can be generalized to arbitrary sets of sentences as follows. A rule subformula of a formula F is an occurrence of an implication in F that does not belong to the antecedent of any implication (Ferraris et al. Reference Ferraris, Lee and Lifschitz2011, Section 7.3; Lee and Meng Reference Lee and Meng2011, Section 3.3). Let I be an interpretation of an arbitrary signature
$\sigma^I$
. It can be generalized to arbitrary sets of sentences as follows. A rule subformula of a formula F is an occurrence of an implication in F that does not belong to the antecedent of any implication (Ferraris et al. Reference Ferraris, Lee and Lifschitz2011, Section 7.3; Lee and Meng Reference Lee and Meng2011, Section 3.3). Let I be an interpretation of an arbitrary signature 
 $\sigma$
, and let
$\sigma$
, and let 
 $\Gamma$
 be a set of sentences over
$\Gamma$
 be a set of sentences over 
 $\sigma^I$
. All vertices of
$\sigma^I$
. All vertices of 
 $G^{sp}_{I}(\Gamma)$
 are elements of
$G^{sp}_{I}(\Gamma)$
 are elements of 
 $I^\downarrow$
. The graph has an edge from A to B iff, for some sentence
$I^\downarrow$
. The graph has an edge from A to B iff, for some sentence 
 $F_1\to F_2$
 obtained from a rule subformula of a member of
$F_1\to F_2$
 obtained from a rule subformula of a member of 
 $\Gamma$
 by substituting names
$\Gamma$
 by substituting names 
 $d^*$
 for its free variables,
$d^*$
 for its free variables, 
 $A\in\mathit{Pos}({F_2},I)$
 and
$A\in\mathit{Pos}({F_2},I)$
 and 
 $B\in\mathit{Pos}({F_1},I)$
.
$B\in\mathit{Pos}({F_1},I)$
.
 For any sentence F, 
 $G^{sp}_{I}(F)$
 stands for
$G^{sp}_{I}(F)$
 stands for 
 $G^{sp}_{I}(\{F\})$
.
$G^{sp}_{I}(\{F\})$
.
Lemma 2 For any HT-interpretation 
 $\langle\mathcal{H},I \rangle$
, any atom M in
$\langle\mathcal{H},I \rangle$
, any atom M in 
 $I^\downarrow \setminus \mathcal{H}$
, and any sentence F over
$I^\downarrow \setminus \mathcal{H}$
, and any sentence F over 
 $\sigma^I$
, if
$\sigma^I$
, if
- (i) for every edge (M,B) of  $G^{sp}_{I}(F)$
, $G^{sp}_{I}(F)$
, $B\in \mathcal{H}$
, $B\in \mathcal{H}$
,
- (ii)  $M\in\mathit{Pos}({F},I)$
, and $M\in\mathit{Pos}({F},I)$
, and
- (iii)  $\langle\mathcal{H},I \rangle\models_{ht} F$
, then $\langle\mathcal{H},I \rangle\models_{ht} F$
, then $\langle I^\downarrow \setminus\{M\},I\rangle\models_{ht} F$
. $\langle I^\downarrow \setminus\{M\},I\rangle\models_{ht} F$
.
Proof By induction on the size of F. Sentence F is neither atomic nor 
 $\bot$
. Indeed, in that case F would be an atomic sentence of the form
$\bot$
. Indeed, in that case F would be an atomic sentence of the form 
 $p(\mathbf{t})$
, where p is intensional, because, by (ii),
$p(\mathbf{t})$
, where p is intensional, because, by (ii), 
 $\mathit{Pos}({F},I)$
 is non-empty. Then, from (iii),
$\mathit{Pos}({F},I)$
 is non-empty. Then, from (iii), 
 $p((\mathbf{t}^I)^*)\in \mathcal{H}$
. On the other hand,
$p((\mathbf{t}^I)^*)\in \mathcal{H}$
. On the other hand, 
 $\mathit{Pos}({F},I)$
 is
$\mathit{Pos}({F},I)$
 is 
 $\{p((\mathbf{t}^I)^*)\}$
, and from (ii) we conclude that
$\{p((\mathbf{t}^I)^*)\}$
, and from (ii) we conclude that 
 $M=p((\mathbf{t}^I)^*)$
. This contradicts the assumption that
$M=p((\mathbf{t}^I)^*)$
. This contradicts the assumption that 
 $M\in I^\downarrow \setminus \mathcal{H} $
. Thus five cases are possible.
$M\in I^\downarrow \setminus \mathcal{H} $
. Thus five cases are possible.
 
Case 1: F is 
 $F_1\land F_2$
. From (iii) we can conclude that
$F_1\land F_2$
. From (iii) we can conclude that 
 $\langle\mathcal{H},I \rangle\models_{ht} F_i$
 for
$\langle\mathcal{H},I \rangle\models_{ht} F_i$
 for 
 $i=1,2$
. It is sufficient to show that
$i=1,2$
. It is sufficient to show that 
 $\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F_i$
; then the conclusion that
$\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F_i$
; then the conclusion that 
 $\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F$
 will follow. Case 1.1:
$\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F$
 will follow. Case 1.1: 
 $M\in\mathit{Pos}({F_i},I)$
, so that formula
$M\in\mathit{Pos}({F_i},I)$
, so that formula 
 $F_i$
 satisfies condition (ii). That formula satisfies condition (i) as well, because
$F_i$
 satisfies condition (ii). That formula satisfies condition (i) as well, because 
 $G^{sp}_{I}(F_i)$
 is a subgraph of
$G^{sp}_{I}(F_i)$
 is a subgraph of 
 $G^{sp}_{I}(F)$
, and it satisfies condition (iii). So the conclusion
$G^{sp}_{I}(F)$
, and it satisfies condition (iii). So the conclusion 
 $\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F_i$
 follows by the induction hypothesis. Case 1.2:
$\langle I^\downarrow \setminus\{M\}, I\rangle\models_{ht} F_i$
 follows by the induction hypothesis. Case 1.2: 
 $M\not\in\mathit{Pos}({F_i},I)$
. Since
$M\not\in\mathit{Pos}({F_i},I)$
. Since 
 $\mathit{Pos}({F_i},I)$
 is a subset of
$\mathit{Pos}({F_i},I)$
 is a subset of 
 $I^\downarrow$
,
$I^\downarrow$
, 
 $\mathit{Pos}({F_i},I)\subseteq I^\downarrow \setminus\{M\}$
. On the other hand, from the fact that
$\mathit{Pos}({F_i},I)\subseteq I^\downarrow \setminus\{M\}$
. On the other hand, from the fact that 
 $\langle\mathcal{H},I \rangle\models_{ht} F_i$
 we conclude, by Proposition 3(a), that
$\langle\mathcal{H},I \rangle\models_{ht} F_i$
 we conclude, by Proposition 3(a), that 
 $I\models F_i$
. By Lemma 1, it follows that
$I\models F_i$
. By Lemma 1, it follows that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_i$
.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_i$
.
 
Case 2: F is 
 $F_1\lor F_2$
. From (iii) we can conclude that
$F_1\lor F_2$
. From (iii) we can conclude that 
 $\langle\mathcal{H},I \rangle\models_{ht} F_i$
 for
$\langle\mathcal{H},I \rangle\models_{ht} F_i$
 for 
 $i=1$
 or
$i=1$
 or 
 $i=2$
. It is sufficient to show that
$i=2$
. It is sufficient to show that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_i$
; then the conclusion that
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_i$
; then the conclusion that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. The reasoning is the same as in Case 1.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. The reasoning is the same as in Case 1.
 
Case 3: F is 
 $F_1\to F_2$
. Then,
$F_1\to F_2$
. Then, 
 $ \mathit{Pos}({F},I)=\mathit{Pos}({F_2},I)$
. By (ii), it follows that
$ \mathit{Pos}({F},I)=\mathit{Pos}({F_2},I)$
. By (ii), it follows that 
 \begin{equation}M\in\mathit{Pos}({F_2},I).\end{equation}
\begin{equation}M\in\mathit{Pos}({F_2},I).\end{equation}
 On the other hand, F is a rule subformula of itself, so that for every atom B in 
 $\mathit{Pos}({F_1},I)$
, (M,B) is an edge of the graph
$\mathit{Pos}({F_1},I)$
, (M,B) is an edge of the graph 
 $G^{sp}_{I}(F)$
. By (i), it follows that every such atom B belongs to
$G^{sp}_{I}(F)$
. By (i), it follows that every such atom B belongs to 
 $\mathcal{H}$
. Consequently
$\mathcal{H}$
. Consequently 
 \begin{equation}\mathit{Pos}({F_1},I)\subseteq \mathcal{H}.\end{equation}
\begin{equation}\mathit{Pos}({F_1},I)\subseteq \mathcal{H}.\end{equation}
 Case 3.1: 
 $\langle\mathcal{H},I \rangle\models_{ht} F_2$
, so that
$\langle\mathcal{H},I \rangle\models_{ht} F_2$
, so that 
 $F_2$
 satisfies condition (iii). Since
$F_2$
 satisfies condition (iii). Since 
 $G^{sp}_{I}(F_2)$
 is a subgraph of
$G^{sp}_{I}(F_2)$
 is a subgraph of 
 $G^{sp}_{I}(F)$
,
$G^{sp}_{I}(F)$
, 
 $F_2$
 satisfies condition (i) as well. By (28),
$F_2$
 satisfies condition (i) as well. By (28), 
 $F_2$
 satisfies condition (ii). Then, by the induction hypothesis,
$F_2$
 satisfies condition (ii). Then, by the induction hypothesis, 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_2$
. Consequently
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F_2$
. Consequently 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
. Case 3.2:
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
. Case 3.2: 
 $\langle\mathcal{H},I \rangle\not\models_{ht} F_2$
. Then, in view of (iii),
$\langle\mathcal{H},I \rangle\not\models_{ht} F_2$
. Then, in view of (iii), 
 $\langle\mathcal{H},I \rangle\not\models_{ht} F_1$
. From this fact and formula (29) we can conclude, by Lemma 1, that
$\langle\mathcal{H},I \rangle\not\models_{ht} F_1$
. From this fact and formula (29) we can conclude, by Lemma 1, that 
 $I \not\models F_1$
. By Proposition 3(a), it follows that
$I \not\models F_1$
. By Proposition 3(a), it follows that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\not\models_{ht} F_1$
, which implies
$\langle I^\downarrow\setminus\{M\},I\rangle\not\models_{ht} F_1$
, which implies 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
.
 
Case 4: F is 
 $\forall X\,G(X)$
. From (iii) we can conclude that for every d in the domain
$\forall X\,G(X)$
. From (iii) we can conclude that for every d in the domain 
 $|I|^s$
, where s is the sort of X,
$|I|^s$
, where s is the sort of X, 
 $\langle\mathcal{H},I \rangle\models_{ht} G(d^*)$
. It is sufficient to show that
$\langle\mathcal{H},I \rangle\models_{ht} G(d^*)$
. It is sufficient to show that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
; then the conclusion that
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
; then the conclusion that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. Case 4.1:
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. Case 4.1: 
 $M\in\mathit{Pos}({G(d^*)},I)$
, so that formula
$M\in\mathit{Pos}({G(d^*)},I)$
, so that formula 
 $G(d^*)$
 satisfies condition (ii). That formula satisfies condition (i) as well, because
$G(d^*)$
 satisfies condition (ii). That formula satisfies condition (i) as well, because 
 $G^{sp}_{I}(G(d^*))$
 is a subgraph of
$G^{sp}_{I}(G(d^*))$
 is a subgraph of 
 $G^{sp}_{I}(F)$
, and it satisfies condition (iii). So the conclusion
$G^{sp}_{I}(F)$
, and it satisfies condition (iii). So the conclusion 
 ${\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)}$
 follows by the induction hypothesis. Case 4.2:
${\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)}$
 follows by the induction hypothesis. Case 4.2: 
 $M\not\in\mathit{Pos}({G(d^*)},I)$
. Since
$M\not\in\mathit{Pos}({G(d^*)},I)$
. Since 
 $\mathit{Pos}({G(d^*)},I)$
 is a subset of
$\mathit{Pos}({G(d^*)},I)$
 is a subset of 
 $I^\downarrow$
, we can conclude that
$I^\downarrow$
, we can conclude that 
 $\mathit{Pos}({G(d^*)},I)\subseteq I^\downarrow \setminus\{M\}$
. On the other hand, from the fact that
$\mathit{Pos}({G(d^*)},I)\subseteq I^\downarrow \setminus\{M\}$
. On the other hand, from the fact that 
 $\langle\mathcal{H},I \rangle\models_{ht} G(d^*)$
 we conclude, by Proposition 3(a), that
$\langle\mathcal{H},I \rangle\models_{ht} G(d^*)$
 we conclude, by Proposition 3(a), that 
 $I\models G(d^*)$
. By Lemma 1, it follows that
$I\models G(d^*)$
. By Lemma 1, it follows that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
.
 
Case 5: F is 
 $\exists X\,G(X)$
. From (iii) we can conclude that for some d in the domain
$\exists X\,G(X)$
. From (iii) we can conclude that for some d in the domain 
 $|I|^s$
, where s is the sort of X,
$|I|^s$
, where s is the sort of X, 
 $\langle\mathcal{H} ,I\rangle\models_{ht} G(d^*)$
. It is sufficient to show that
$\langle\mathcal{H} ,I\rangle\models_{ht} G(d^*)$
. It is sufficient to show that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
; then the conclusion that
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} G(d^*)$
; then the conclusion that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. The reasoning is the same as in Case 4.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 will follow. The reasoning is the same as in Case 4.
Lemma 3 For any interpretation I of 
 $\sigma$
 and any set
$\sigma$
 and any set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma^I$
 such that the graph
$\sigma^I$
 such that the graph 
 $G^{sp}_I(\Gamma)$
 has no infinite walks, I is a stable model of
$G^{sp}_I(\Gamma)$
 has no infinite walks, I is a stable model of 
 $\Gamma$
 iff I is pointwise stable.
$\Gamma$
 iff I is pointwise stable.
Proof We need to show that if I is a model of 
 $\Gamma$
 such that the graph
$\Gamma$
 such that the graph 
 $G^{sp}_{I}(\Gamma)$
 has no infinite walks, and there exists a proper subset
$G^{sp}_{I}(\Gamma)$
 has no infinite walks, and there exists a proper subset 
 $\mathcal{H}$
 of
$\mathcal{H}$
 of 
 $I^\downarrow$
 such that
$I^\downarrow$
 such that 
 $\langle\mathcal{H},I\rangle$
 satisfies
$\langle\mathcal{H},I\rangle$
 satisfies 
 $\Gamma$
, then a subset with this property can be obtained from
$\Gamma$
, then a subset with this property can be obtained from 
 $I^\downarrow$
 by removing a single element.
$I^\downarrow$
 by removing a single element.
 The set 
 $I^\downarrow \setminus \mathcal{H}$
 contains an atom M such that for every edge (M,B) of the graph
$I^\downarrow \setminus \mathcal{H}$
 contains an atom M such that for every edge (M,B) of the graph 
 $G^{sp}_{I}(\Gamma)$
,
$G^{sp}_{I}(\Gamma)$
, 
 $B\not\in I^\downarrow \setminus \mathcal{H}$
. Indeed, otherwise this graph would have an infinite walk consisting of elements of
$B\not\in I^\downarrow \setminus \mathcal{H}$
. Indeed, otherwise this graph would have an infinite walk consisting of elements of 
 $I^\downarrow \setminus \mathcal{H}$
. On the other hand, for every such edge,
$I^\downarrow \setminus \mathcal{H}$
. On the other hand, for every such edge, 
 $B\in I^\downarrow$
. Indeed, from the definition of the graph
$B\in I^\downarrow$
. Indeed, from the definition of the graph 
 $G^{sp}_I(\Gamma)$
 we see that for every edge (M,B) of that graph, B belongs to the set
$G^{sp}_I(\Gamma)$
 we see that for every edge (M,B) of that graph, B belongs to the set 
 $\mathit{Pos}({F},I)$
 for some sentence F, and that set is contained in
$\mathit{Pos}({F},I)$
 for some sentence F, and that set is contained in 
 $I^\downarrow$
. Consequently for every edge (M,B) of
$I^\downarrow$
. Consequently for every edge (M,B) of 
 $G^{sp}_{I}(\Gamma)$
,
$G^{sp}_{I}(\Gamma)$
, 
 $B\in \mathcal{H}$
.
$B\in \mathcal{H}$
.
 We will show that 
 $\langle I^\downarrow\setminus\{M\},I\rangle$
 satisfies
$\langle I^\downarrow\setminus\{M\},I\rangle$
 satisfies 
 $\Gamma$
. Take a sentence F from
$\Gamma$
. Take a sentence F from 
 $\Gamma$
. Case 1:
$\Gamma$
. Case 1: 
 $M\in\mathit{Pos}({F},I)$
. Then, condition (ii) of Lemma 2 is satisfied for the HT-interpretation
$M\in\mathit{Pos}({F},I)$
. Then, condition (ii) of Lemma 2 is satisfied for the HT-interpretation 
 $\langle\mathcal{H},I\rangle$
. Condition (i) is satisfied for this HT-interpretation as well, because
$\langle\mathcal{H},I\rangle$
. Condition (i) is satisfied for this HT-interpretation as well, because 
 $G^{sp}_{I}(F)$
 is a subgraph of
$G^{sp}_{I}(F)$
 is a subgraph of 
 $G^{sp}_{I}(\Gamma)$
; furthermore, condition (iii) is satisfied because
$G^{sp}_{I}(\Gamma)$
; furthermore, condition (iii) is satisfied because 
 $\langle\mathcal{H},I\rangle$
 satisfies
$\langle\mathcal{H},I\rangle$
 satisfies 
 $\Gamma$
. Consequently
$\Gamma$
. Consequently 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 by Lemma 2. Case 2:
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 by Lemma 2. Case 2: 
 $M\not\in\mathit{Pos}({F},I)$
. Then,
$M\not\in\mathit{Pos}({F},I)$
. Then, 
 $\mathit{Pos}({F},I)\subseteq I^\downarrow\setminus\{M\}$
. Since
$\mathit{Pos}({F},I)\subseteq I^\downarrow\setminus\{M\}$
. Since 
 $I \models F$
, we can conclude that
$I \models F$
, we can conclude that 
 $\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 by Lemma 1.
$\langle I^\downarrow\setminus\{M\},I\rangle\models_{ht} F$
 by Lemma 1.
 A model I of a set 
 $\Gamma$
 of completable sentences over
$\Gamma$
 of completable sentences over 
 $\sigma$
 is supported if for every atom
$\sigma$
 is supported if for every atom 
 $p(\mathbf{d}^*)$
 in
$p(\mathbf{d}^*)$
 in 
 $I^\downarrow$
 there exists an instance
$I^\downarrow$
 there exists an instance 
 $F\to p(\mathbf{d}^*)$
 of a member of
$F\to p(\mathbf{d}^*)$
 of a member of 
 $\Gamma$
 such that
$\Gamma$
 such that 
 $I \models F$
.
$I \models F$
.
Lemma 4 Every pointwise stable model of a completable set of sentences is supported.
Proof. Let I be a pointwise stable model of a completable set 
 $\Gamma$
 of sentences. Take an atom
$\Gamma$
 of sentences. Take an atom 
 $p(\mathbf{d}^*)$
 from
$p(\mathbf{d}^*)$
 from 
 $I^\downarrow$
. We need to find an instance
$I^\downarrow$
. We need to find an instance 
 $F\to p(\mathbf{d}^*)$
 of a completable sentence from
$F\to p(\mathbf{d}^*)$
 of a completable sentence from 
 $\Gamma$
 such that
$\Gamma$
 such that 
 $I\models F$
.
$I\models F$
.
 By the definition of a pointwise stable model, 
 $\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle$
 does not satisfy
$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle$
 does not satisfy 
 $\Gamma$
. Then, one of the completable sentences from
$\Gamma$
. Then, one of the completable sentences from 
 $\Gamma$
 has an instance
$\Gamma$
 has an instance 
 $F\to G$
 such that
$F\to G$
 such that 
 \begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\not\models_{ht} F\to G$}.\end{equation}
\begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\not\models_{ht} F\to G$}.\end{equation}
 We will show that this instance has the required properties. Since I is a model of 
 $\Gamma$
,
$\Gamma$
, 
 \begin{equation}I\models F\to G.\end{equation}
\begin{equation}I\models F\to G.\end{equation}
From (30) and (31) we conclude that
 \begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\models_{ht} F,$}\end{equation}
\begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\models_{ht} F,$}\end{equation}
and
 \begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\not\models_{ht} G$}.\end{equation}
\begin{equation}\hbox{$\langle I^\downarrow\setminus\{p(\mathbf{d}^*)\},I\rangle\not\models_{ht} G$}.\end{equation}
 From (32) and Proposition 3(a), 
 $I\models F$
. Then, in view of (31),
$I\models F$
. Then, in view of (31), 
 \begin{equation}I\models G.\end{equation}
\begin{equation}I\models G.\end{equation}
 From (33), (34) and Proposition 3(c) we can conclude that formula Gd contains p, so that it has the form 
 $p(\mathbf{e}^*)$
 for some tuple of domain elements
$p(\mathbf{e}^*)$
 for some tuple of domain elements 
 $\mathbf{e}$
. Then, from (34),
$\mathbf{e}$
. Then, from (34), 
 $p(\mathbf{e}^*)\in I^\downarrow$
, and from (33),
$p(\mathbf{e}^*)\in I^\downarrow$
, and from (33), 
 $p(\mathbf{e}^*)\not\in I^\downarrow \setminus\{p(\mathbf{d}^*)\}$
. Consequently
$p(\mathbf{e}^*)\not\in I^\downarrow \setminus\{p(\mathbf{d}^*)\}$
. Consequently 
 $p(\mathbf{e}^*)$
 is
$p(\mathbf{e}^*)$
 is 
 $p(\mathbf{d}^*)$
, so that
$p(\mathbf{d}^*)$
, so that 
 $\mathbf{e}=\mathbf{d}$
.
$\mathbf{e}=\mathbf{d}$
.
Lemma 5 For any interpretation I of 
 $\sigma$
 and any completable set
$\sigma$
 and any completable set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma$
 such that the graph
$\sigma$
 such that the graph 
 $G^{sp}_I(\Gamma)$
 has no infinite walks, I is a supported model of
$G^{sp}_I(\Gamma)$
 has no infinite walks, I is a supported model of 
 $\Gamma$
 iff I is stable.
$\Gamma$
 iff I is stable.
Proof The if part follows from Lemmas 3 and 4. For the only if part, consider a supported model I of a completable set 
 $\Gamma$
 of sentences such that the graph
$\Gamma$
 of sentences such that the graph 
 $G^{sp}_{I}(\Gamma)$
 has no infinite walks; we need to prove that I is stable. According to Lemma 3, it is sufficient to check that I is pointwise stable.
$G^{sp}_{I}(\Gamma)$
 has no infinite walks; we need to prove that I is stable. According to Lemma 3, it is sufficient to check that I is pointwise stable.
 Take any atom M in 
 $I^\downarrow$
; we will show that
$I^\downarrow$
; we will show that 
 $\langle I^\downarrow\setminus\{M\}, I\rangle$
 is not an HT-model of
$\langle I^\downarrow\setminus\{M\}, I\rangle$
 is not an HT-model of 
 $\Gamma$
. Since I is supported, one of the completable sentences in
$\Gamma$
. Since I is supported, one of the completable sentences in 
 $\Gamma$
 has an instance
$\Gamma$
 has an instance 
 ${F\to M}$
 such that
${F\to M}$
 such that 
 ${I\models F}$
. Atom M does not belong to
${I\models F}$
. Atom M does not belong to 
 $\mathit{Pos}({F},I)$
, because otherwise
$\mathit{Pos}({F},I)$
, because otherwise 
 $M,M,\dots$
 would be an infinite walk in
$M,M,\dots$
 would be an infinite walk in 
 $G^{sp}_{I}(\Gamma)$
. Since the set
$G^{sp}_{I}(\Gamma)$
. Since the set 
 $\mathit{Pos}({F},I)$
 is a subset of
$\mathit{Pos}({F},I)$
 is a subset of 
 $I^\downarrow$
, we can conclude that it is a subset of
$I^\downarrow$
, we can conclude that it is a subset of 
 $I^\downarrow\setminus\{M\}$
. By Lemma 1, it follows that
$I^\downarrow\setminus\{M\}$
. By Lemma 1, it follows that 
 $\langle I^\downarrow\setminus\{M\}, I\rangle\models_{ht} F$
. Therefore
$\langle I^\downarrow\setminus\{M\}, I\rangle\models_{ht} F$
. Therefore 
 $\langle I^\downarrow\setminus\{M\}, I\rangle\not\models_{ht} F\to M$
.
$\langle I^\downarrow\setminus\{M\}, I\rangle\not\models_{ht} F\to M$
.
Lemma 6 For any interpretation I of 
 $\sigma$
 and any completable set
$\sigma$
 and any completable set 
 $\Gamma$
 sentences over
$\Gamma$
 sentences over 
 $\sigma$
, I is a supported model of
$\sigma$
, I is a supported model of 
 $\Gamma$
 iff
$\Gamma$
 iff 
 $I\models\mathrm{COMP}[\Gamma]$
.
$I\models\mathrm{COMP}[\Gamma]$
.
Proof Let the sentences defining an intensional predicate symbol p in 
 $\Gamma$
 be
$\Gamma$
 be 
 \begin{equation}\forall \mathbf{U}_i\mathbf{V}(F_i(\mathbf{U}_i,\mathbf{V})\to p(\mathbf{V}))\qquad ( i=1,\dots,k).\end{equation}
\begin{equation}\forall \mathbf{U}_i\mathbf{V}(F_i(\mathbf{U}_i,\mathbf{V})\to p(\mathbf{V}))\qquad ( i=1,\dots,k).\end{equation}
The completed definition of p is
 $$\forall {\mathbf{V}}\left(p({\mathbf{V}}) \leftrightarrow \bigvee_{i = 1}^k \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\right).$$
$$\forall {\mathbf{V}}\left(p({\mathbf{V}}) \leftrightarrow \bigvee_{i = 1}^k \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\right).$$
Hence, an interpretation I of 
 $\sigma$
 satisfies
$\sigma$
 satisfies 
 $\mathrm{COMP}[\Gamma]$
 iff the following three conditions hold:
$\mathrm{COMP}[\Gamma]$
 iff the following three conditions hold:
- (a) for every intensional p, I satisfies the sentence  $$\forall {\mathbf{V}}\left(p({\mathbf{V}}) \to \bigvee_{i = 1}^k \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\right);$$ $$\forall {\mathbf{V}}\left(p({\mathbf{V}}) \to \bigvee_{i = 1}^k \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\right);$$
- (b) for every intensional p and for every i, I satisfies the sentence (36) \begin{equation}\forall {\mathbf{V}}( \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\to p({\mathbf{V}}));\end{equation} \begin{equation}\forall {\mathbf{V}}( \exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{V})\to p({\mathbf{V}}));\end{equation}
- (c) I satisfies all constraints of  $\Gamma$
. $\Gamma$
.
 Since (36) is equivalent to (35), I is a model of 
 $\Gamma$
 if and only if conditions (b) and (c) hold. It remains to check that condition (a) holds if and only if the model I is supported.
$\Gamma$
 if and only if conditions (b) and (c) hold. It remains to check that condition (a) holds if and only if the model I is supported.
Condition (a) can be expressed by saying that
- for every atom  $p(\mathbf{d}^*)$
 in $p(\mathbf{d}^*)$
 in $I^\downarrow$
 there exists i such that $I^\downarrow$
 there exists i such that $I\models\exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{d}^*),$ $I\models\exists \mathbf{U}_i \, F_i(\mathbf{U}_i,\mathbf{d}^*),$
or, equivalently, that
- for every atom  $p(\mathbf{d}^*)$
 in $p(\mathbf{d}^*)$
 in $I^\downarrow$
 there exist i and a tuple $I^\downarrow$
 there exist i and a tuple $\mathbf{d}_i$
 of domain elements $\mathbf{d}_i$
 of domain elements
 such that 
 $I\models F_i(\mathbf{d}_i^*,\mathbf{d}^*)$
.
$I\models F_i(\mathbf{d}_i^*,\mathbf{d}^*)$
.
 Since the members of 
 $\Gamma$
 defining p are sentences of form (35), the last condition expresses that I is a supported model of
$\Gamma$
 defining p are sentences of form (35), the last condition expresses that I is a supported model of 
 $\Gamma$
.
$\Gamma$
.
The assertion of the Main Lemma follows from Lemmas 5 and 6.
8 Proof of Theorem 1
The proof of Theorem 1 refers to infinitary propositional formulas and the strong equivalence relation between them (Harrison et al. Reference Harrison, Lifschitz, Pearce and Valverde2017).
 Translations 
 $\tau$
 and
$\tau$
 and 
 $\tau^*$
 are related by a third translation
$\tau^*$
 are related by a third translation 
 $F\mapsto F^\mathrm{prop}$
 (Lifschitz et al. Reference Lifschitz, Lühne and Schaub2019, Section 5), which transforms sentences over
$F\mapsto F^\mathrm{prop}$
 (Lifschitz et al. Reference Lifschitz, Lühne and Schaub2019, Section 5), which transforms sentences over 
 $\sigma_0$
 into infinitary propositional combinations of precomputed atoms. This translation is defined as follows:
$\sigma_0$
 into infinitary propositional combinations of precomputed atoms. This translation is defined as follows:
- • if F is  $p(t_1,\dotsc,t_n)$
, then $p(t_1,\dotsc,t_n)$
, then $F^\mathrm{prop}$
 is obtained from F by replacing each $F^\mathrm{prop}$
 is obtained from F by replacing each $t_i$
 by the value obtained after evaluating all arithmetic functions in $t_i$
 by the value obtained after evaluating all arithmetic functions in $t_i$
; $t_i$
;
- • if F is  $t_1 \,\mathit{rel}\, t_2$
, then $t_1 \,\mathit{rel}\, t_2$
, then $F^\mathrm{prop}$
 is $F^\mathrm{prop}$
 is $\top$
 if the values of $\top$
 if the values of $t_1$
 and $t_1$
 and $t_2$
 are in the relation $t_2$
 are in the relation $\mathit{rel}$
, and $\mathit{rel}$
, and $\bot$
 otherwise; $\bot$
 otherwise;
- •  $\bot^\mathrm{prop}$
 is $\bot^\mathrm{prop}$
 is $\bot$
; $\bot$
;
- •  $(F \odot G)^\mathrm{prop}$
 is $(F \odot G)^\mathrm{prop}$
 is $F^\mathrm{prop} \odot G^\mathrm{prop}$
 for every binary connective $F^\mathrm{prop} \odot G^\mathrm{prop}$
 for every binary connective $\odot$
; $\odot$
;
- •  $(\forall X\, F(X))^\mathrm{prop}$
 is the conjunction of the formulas $(\forall X\, F(X))^\mathrm{prop}$
 is the conjunction of the formulas $F(r)^\mathrm{prop}$
 over all precomputed terms r if X is a general variable, and over all numerals r if X is an integer variable; $F(r)^\mathrm{prop}$
 over all precomputed terms r if X is a general variable, and over all numerals r if X is an integer variable;
- •  $(\exists X\, F(X))^\mathrm{prop}$
 is the disjunction of the formulas $(\exists X\, F(X))^\mathrm{prop}$
 is the disjunction of the formulas $F(r)^\mathrm{prop}$
 over all precomputed terms r if X is a general variable, and over all numerals r if X is an integer variable. $F(r)^\mathrm{prop}$
 over all precomputed terms r if X is a general variable, and over all numerals r if X is an integer variable.
This translation is similar to the grounding operation defined by Truszczynski (Reference Truszczynski, Erdem, Lee, Lierler and Pearce2012, Section 2). The following proposition, analogous to Proposition 2 from Truszczynski’s paper and to Proposition 3 by Lifschitz et al. (Reference Lifschitz, Lühne and Schaub2019), relates the meaning of a sentence to the meaning of its propositional translation. It differs from the last result in view of the fact that the division and modulo operations are treated here in a different way (see Section 2.1.2 and Footnote 2), but can be proved in a similar way.
Proposition 2 For any rule R, 
 $(\tau^*R)^\mathrm{prop}$
 is strongly equivalent to
$(\tau^*R)^\mathrm{prop}$
 is strongly equivalent to 
 $\tau R$
.
$\tau R$
.
 Since standard interpretations of 
 $\sigma_0$
 are semi-Herbrand (Section 6), the correspondence between tuples d of elements of domains of a standard interpretation and tuples
$\sigma_0$
 are semi-Herbrand (Section 6), the correspondence between tuples d of elements of domains of a standard interpretation and tuples 
 ${\bf d}^*$
 of their names is one-to-one, and we take the liberty to identify them. Therefore, for a standard interpretation I of
${\bf d}^*$
 of their names is one-to-one, and we take the liberty to identify them. Therefore, for a standard interpretation I of 
 $\sigma_0$
,
$\sigma_0$
, 
 $I^\downarrow$
 is identified with the set of precomputed atoms that are satisfied by I. In view of this convention, the transformation
$I^\downarrow$
 is identified with the set of precomputed atoms that are satisfied by I. In view of this convention, the transformation 
 $I\mapsto I^\downarrow$
 is the inverse of the transformation
$I\mapsto I^\downarrow$
 is the inverse of the transformation 
 $\mathcal{J}\mapsto \mathcal{J}^\uparrow$
, defined in Section 2.3: for any set
$\mathcal{J}\mapsto \mathcal{J}^\uparrow$
, defined in Section 2.3: for any set 
 $\mathcal{J}$
 of precomputed atoms over
$\mathcal{J}$
 of precomputed atoms over 
 $\sigma_0$
,
$\sigma_0$
, 
 \begin{equation}(\mathcal{J}^\uparrow)^\downarrow=\mathcal{J}.\end{equation}
\begin{equation}(\mathcal{J}^\uparrow)^\downarrow=\mathcal{J}.\end{equation}
Lemma 7 (Fandinno and Lifschitz Reference Fandinno and Lifschitz2023, Lemma 2(i)) A standard interpretation I of 
 $\sigma_0$
 satisfies a sentence F over
$\sigma_0$
 satisfies a sentence F over 
 $\sigma_0$
 iff
$\sigma_0$
 iff 
 $I^\downarrow$
 satisfies
$I^\downarrow$
 satisfies 
 $F^\mathrm{prop}$
.
$F^\mathrm{prop}$
.
The lemma below relates the meaning of a sentence in the logic of here-and-there to the meaning of its grounding in the infinitary version of that logic (Truszczynski Reference Truszczynski, Erdem, Lee, Lierler and Pearce2012, Section 2). It is similar to Proposition 4 from that paper and can be proved by induction in a similar way.
Lemma 8 A standard HT-interpretation 
 $\langle \mathcal{H},I\rangle$
 of
$\langle \mathcal{H},I\rangle$
 of 
 $\sigma_0$
 satisfies a sentence F over
$\sigma_0$
 satisfies a sentence F over 
 $\sigma_0$
 iff
$\sigma_0$
 iff 
 $\langle \mathcal{H},I^\downarrow\rangle$
 satisfies
$\langle \mathcal{H},I^\downarrow\rangle$
 satisfies 
 $F^\mathrm{prop}$
.
$F^\mathrm{prop}$
.
The following lemma relates stable models of first-order formulas (as defined in Appendix B) to stable models of infinitary propositional formulas (Truszczynski Reference Truszczynski, Erdem, Lee, Lierler and Pearce2012, Section 2). It is a generalization of Theorem 5 from that paper.
Lemma 9 A standard interpretation I of 
 $\sigma_0$
 is a stable model of a set
$\sigma_0$
 is a stable model of a set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma_0$
 iff
$\sigma_0$
 iff 
 $I^\downarrow$
 is a stable model of
$I^\downarrow$
 is a stable model of 
 $\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
.
$\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
.
Proof By Lemma 7, an interpretation I is a model of 
 $\Gamma$
 iff
$\Gamma$
 iff 
 $I^\downarrow$
 is a model of
$I^\downarrow$
 is a model of 
 $\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
. By Lemma 8, for any proper subset
$\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
. By Lemma 8, for any proper subset 
 $\mathcal{H}$
 of
$\mathcal{H}$
 of 
 $I^\downarrow$
,
$I^\downarrow$
, 
 $\langle\mathcal{H},I\rangle$
 satisfies
$\langle\mathcal{H},I\rangle$
 satisfies 
 $\Gamma$
 iff
$\Gamma$
 iff 
 $\langle\mathcal{H},I^\downarrow\rangle$
 satisfies
$\langle\mathcal{H},I^\downarrow\rangle$
 satisfies 
 $\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
.
$\{F^\mathrm{prop}\,:\,F\in\Gamma\}$
.
Proof of Theorem 1 For any set 
 $\mathcal{J}$
 of precomputed atoms and any mini-gringo program
$\mathcal{J}$
 of precomputed atoms and any mini-gringo program 
 $\Pi$
,
$\Pi$
,
 $\mathcal{J}^{\uparrow}$
 is a stable model of $\mathcal{J}^{\uparrow}$
 is a stable model of $\tau^*\Pi$ $\tau^*\Pi$- iff 
 $(\mathcal{J}^{\uparrow})^{\downarrow}$
 is a stable model of $(\mathcal{J}^{\uparrow})^{\downarrow}$
 is a stable model of $\{ F^\mathrm{ prop} : F \in \tau^*\Pi\}$
 (Lemma 9) $\{ F^\mathrm{ prop} : F \in \tau^*\Pi\}$
 (Lemma 9)- iff 
 $\mathcal{J}$
 is a stable model of $\mathcal{J}$
 is a stable model of $\{ F^\mathrm{prop} : F \in \tau^*\Pi\}$
 (formula (37)) $\{ F^\mathrm{prop} : F \in \tau^*\Pi\}$
 (formula (37))- iff 
 $\mathcal{J}$
 is a stable model of $\mathcal{J}$
 is a stable model of $\{ (\tau^*R)^\mathrm{prop} : R \in\Pi\}$
 (definition of $\{ (\tau^*R)^\mathrm{prop} : R \in\Pi\}$
 (definition of $\tau^*\Pi$
) $\tau^*\Pi$
)- iff 
 $\mathcal{J}$
 is a stable model of $\mathcal{J}$
 is a stable model of $\{ \tau R : R \in\Pi\}$
 (Proposition 2) $\{ \tau R : R \in\Pi\}$
 (Proposition 2)- iff 
 $\mathcal{J}$
 is a stable model of $\mathcal{J}$
 is a stable model of $\Pi$
 (semantics of mini-gringo). $\Pi$
 (semantics of mini-gringo).
9 Proof of Theorem 2
 The equivalence between conditions (b) and (c) in the statement of Theorem 2 follows from the fact that for every sentence F over 
 $\sigma_0$
 (first-order or second-order),
$\sigma_0$
 (first-order or second-order), 
 $\mathcal{P}^\uparrow$
 satisfies v(F) iff
$\mathcal{P}^\uparrow$
 satisfies v(F) iff 
 $\mathcal{P}^v$
 satisfies F. The equivalence between conditions (a) and (b) will be derived from the Main Lemma. To this end, we need to relate the positive dependency graph of an io-program to the positive dependency graph of the corresponding completable set of sentences with respect to a standard interpretation of
$\mathcal{P}^v$
 satisfies F. The equivalence between conditions (a) and (b) will be derived from the Main Lemma. To this end, we need to relate the positive dependency graph of an io-program to the positive dependency graph of the corresponding completable set of sentences with respect to a standard interpretation of 
 $\sigma_0$
. Such a relationship is described by Lemma 14 below.
$\sigma_0$
. Such a relationship is described by Lemma 14 below.
Lemma 10 For any tuple 
 $\bf t$
 of ground terms in the language of mini-gringo and for any tuple
$\bf t$
 of ground terms in the language of mini-gringo and for any tuple 
 $\bf r$
 of precomputed terms of the same length, the formula
$\bf r$
 of precomputed terms of the same length, the formula 
 $\mathit{val}_{{\bf t}}({\bf r})$
 is equivalent to
$\mathit{val}_{{\bf t}}({\bf r})$
 is equivalent to 
 $\top$
 if
$\top$
 if 
 ${\bf r} \in [{\bf t}]$
, and to
${\bf r} \in [{\bf t}]$
, and to 
 $\bot$
 otherwise.
$\bot$
 otherwise.
Proof The special case when 
 $\bf t$
 is a single term is Lemma 1 by Lifschitz et al. (Reference Lifschitz, Lühne and Schaub2020). The general case easily follows.
$\bf t$
 is a single term is Lemma 1 by Lifschitz et al. (Reference Lifschitz, Lühne and Schaub2020). The general case easily follows.
 The following lemma describes properties of the transformation 
 $\tau^B$
, defined in Section 2.4.
$\tau^B$
, defined in Section 2.4.
Lemma 11 For any set 
 $\mathcal{J}$
 of precomputed atoms and any ground literal L such that
$\mathcal{J}$
 of precomputed atoms and any ground literal L such that 
 $\mathcal{J}^\uparrow \models \tau^B(L)$
,
$\mathcal{J}^\uparrow \models \tau^B(L)$
,
- (a) If L is  $p({\bf t})$
 or $p({\bf t})$
 or $\textit{not}\ \textit{not}\ p({\bf t})$
 then, for some tuple $\textit{not}\ \textit{not}\ p({\bf t})$
 then, for some tuple $\bf r$
 in $\bf r$
 in $[{\bf t}]$
, $[{\bf t}]$
, $p({\bf r})\in\mathcal{J}$
. $p({\bf r})\in\mathcal{J}$
.
- (b) If L is  $\textit{not}\ p({\bf t})$
 then, for some tuple $\textit{not}\ p({\bf t})$
 then, for some tuple $\bf r$
 in $\bf r$
 in $[{\bf t}]$
, $[{\bf t}]$
, $p({\bf r})\not\in\mathcal{J}$
. $p({\bf r})\not\in\mathcal{J}$
.
Proof Consider the case when L is 
 $p({\bf t})$
. Then,
$p({\bf t})$
. Then, 
 $\tau^B(L)$
 is
$\tau^B(L)$
 is 
 $\exists {\bf V}(\mathit{val}_{{\bf t}}({\bf V}) \land p({\bf V}))$
. Since
$\exists {\bf V}(\mathit{val}_{{\bf t}}({\bf V}) \land p({\bf V}))$
. Since 
 $\mathcal{J}^\uparrow$
 satisfies this formula, there exists a tuple
$\mathcal{J}^\uparrow$
 satisfies this formula, there exists a tuple 
 $\bf r$
 of precomputed terms such that
$\bf r$
 of precomputed terms such that 
 $\mathcal{J}^\uparrow$
 satisfies
$\mathcal{J}^\uparrow$
 satisfies 
 $\mathit{val}_{{\bf t}}({\bf r})$
 and
$\mathit{val}_{{\bf t}}({\bf r})$
 and 
 $p({\bf r})$
. Since
$p({\bf r})$
. Since 
 $\mathit{val}_{{\bf t}}({\bf r})$
 is satisfiable, we can conclude by Lemma 10 that
$\mathit{val}_{{\bf t}}({\bf r})$
 is satisfiable, we can conclude by Lemma 10 that 
 ${\bf r}\in[{\bf t}]$
. The other two cases are analogous.
${\bf r}\in[{\bf t}]$
. The other two cases are analogous.
Lemma 12 If 
 $\bf U$
 is a tuple of general variables, and
$\bf U$
 is a tuple of general variables, and 
 $\bf u$
 is a tuple of precomputed terms of the same length, then
$\bf u$
 is a tuple of precomputed terms of the same length, then
- (a) for any term  $t({\bf U})$
 and any precomputed term r, the result of substituting $t({\bf U})$
 and any precomputed term r, the result of substituting $\bf u$
 for $\bf u$
 for $\bf U$
 in $\bf U$
 in $\mathit{val}_{t({\bf U})}(r)$
 is $\mathit{val}_{t({\bf U})}(r)$
 is $\mathit{val}_{t({\bf u})}(r)$
; $\mathit{val}_{t({\bf u})}(r)$
;
- (b) for any conjunction  $\mathit{Body}({\bf U})$
 of literals and comparisons, the result of substituting $\mathit{Body}({\bf U})$
 of literals and comparisons, the result of substituting $\bf u$
 for $\bf u$
 for $\bf U$
 in $\bf U$
 in $\tau^B(\mathit{Body}({\bf U}))$
 is $\tau^B(\mathit{Body}({\bf U}))$
 is $\tau^B(\mathit{Body}({\bf u}))$
. $\tau^B(\mathit{Body}({\bf u}))$
.
Proof Part (i) is easy to prove by induction. Part (ii) immediately follows.
 In the rest of this section, v is a valuation on the set of placeholders of an io-program 
 $\Omega$
, and
$\Omega$
, and 
 $\mathcal{J}$
 is a set of precomputed atoms that do not contain placeholders of
$\mathcal{J}$
 is a set of precomputed atoms that do not contain placeholders of 
 $\Omega$
. Standard interpretations of
$\Omega$
. Standard interpretations of 
 $\sigma_0$
 are semi-Herbrand, and the references to Pos and
$\sigma_0$
 are semi-Herbrand, and the references to Pos and 
 $G^{sp}$
 below refer to the definitions modified as described at the end of Section 6.
$G^{sp}$
 below refer to the definitions modified as described at the end of Section 6.
Lemma 13 Let 
 $\bf U$
 be a list of distinct general variables, and let
$\bf U$
 be a list of distinct general variables, and let 
 $p({\bf t}({\bf U})) \leftarrow \mathit{Body}({\bf U})$
 be a basic rule of
$p({\bf t}({\bf U})) \leftarrow \mathit{Body}({\bf U})$
 be a basic rule of 
 $\Omega$
 with all variables explicitly shown. For any tuple
$\Omega$
 with all variables explicitly shown. For any tuple 
 $\bf u$
 of precomputed terms of the same length as
$\bf u$
 of precomputed terms of the same length as 
 $\bf U$
, any tuple
$\bf U$
, any tuple 
 $\bf r$
 from
$\bf r$
 from 
 $[v({\bf t}({\bf u}))]$
, and any precomputed atom A from
$[v({\bf t}({\bf u}))]$
, and any precomputed atom A from 
 $\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
, the positive dependency graph of
$\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
, the positive dependency graph of 
 $\Omega$
 for the input
$\Omega$
 for the input 
 $(v,\mathcal{J}^{in})$
 has an edge from
$(v,\mathcal{J}^{in})$
 has an edge from 
 $p({\bf r})$
 to A.
$p({\bf r})$
 to A.
Proof We will show that the instance
 $$p(v({\bf t}({\bf u}))) \leftarrow v(\mathit{Body}({\bf u})),$$
$$p(v({\bf t}({\bf u}))) \leftarrow v(\mathit{Body}({\bf u})),$$
of the rule
 $$p(v({\bf t}({\bf U}))) \leftarrow v(\mathit{Body}({\bf U})),$$
$$p(v({\bf t}({\bf U}))) \leftarrow v(\mathit{Body}({\bf U})),$$
satisfies conditions (a)–(e) imposed on R in the definition of the positive dependency graph of an io-program (see Section 4).
 Verification of condition (a): the argument of p in the head of R is 
 $v({\bf t}({\bf u}))$
, and
$v({\bf t}({\bf u}))$
, and 
 ${\bf r} \in [v({\bf t}({\bf u}))]$
.
${\bf r} \in [v({\bf t}({\bf u}))]$
.
 Verification of condition (b): since 
 $A\in\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
, the body
$A\in\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
, the body 
 $v(\mathit{Body}({\bf u}))$
 of R has a conjunctive term
$v(\mathit{Body}({\bf u}))$
 of R has a conjunctive term 
 $p'({\bf r}')$
 such that
$p'({\bf r}')$
 such that 
 $$A\in\mathit{Pos}({\tau^B(p'({\bf r}'))},\mathcal{J}^\uparrow) =\mathit{Pos}({\exists {\bf V}({\bf r}'={\bf V} \land p'({\bf V}))},\mathcal{J}^\uparrow) =\mathit{Pos}({p'({\bf r}'))},\mathcal{J}^\uparrow)\subseteq\{p'({\bf r}')\}.$$
$$A\in\mathit{Pos}({\tau^B(p'({\bf r}'))},\mathcal{J}^\uparrow) =\mathit{Pos}({\exists {\bf V}({\bf r}'={\bf V} \land p'({\bf V}))},\mathcal{J}^\uparrow) =\mathit{Pos}({p'({\bf r}'))},\mathcal{J}^\uparrow)\subseteq\{p'({\bf r}')\}.$$
 It follows that 
 $A=p'({\bf r}')$
, so that A is a conjunctive term of the body required by condition (b).
$A=p'({\bf r}')$
, so that A is a conjunctive term of the body required by condition (b).
 Verification of conditions (c)–(e): let L be a conjunctive term of the body 
 $v(\mathit{Body}({\bf u}))$
 of R that contains an input symbol of
$v(\mathit{Body}({\bf u}))$
 of R that contains an input symbol of 
 $\Omega$
 or is a comparison. Since
$\Omega$
 or is a comparison. Since 
 $\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
 is non-empty,
$\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow)$
 is non-empty, 
 $\tau^B(v(\mathit{Body}({\bf u})))$
 is satisfied by
$\tau^B(v(\mathit{Body}({\bf u})))$
 is satisfied by 
 $\mathcal{J}^\uparrow$
. Therefore, the conjunctive term
$\mathcal{J}^\uparrow$
. Therefore, the conjunctive term 
 $\tau^B(L)$
 of that formula is satisfied by
$\tau^B(L)$
 of that formula is satisfied by 
 $\mathcal{J}^\uparrow$
 as well. If L has the form
$\mathcal{J}^\uparrow$
 as well. If L has the form 
 $q({\bf t})$
 or
$q({\bf t})$
 or 
 $\textit{not}\ \textit{not}\ q({\bf t})$
 then, by Lemma 11(a), there exists a tuple
$\textit{not}\ \textit{not}\ q({\bf t})$
 then, by Lemma 11(a), there exists a tuple 
 ${\bf r}'$
 in
${\bf r}'$
 in 
 $[{\bf t}]$
 such that
$[{\bf t}]$
 such that 
 $q({\bf r}')\in\mathcal{J}$
, and consequently
$q({\bf r}')\in\mathcal{J}$
, and consequently 
 $q({\bf r}')\in\mathcal{J}^{in}$
. If L has the form
$q({\bf r}')\in\mathcal{J}^{in}$
. If L has the form 
 $\textit{not}\ q({\bf t})$
 then, by Lemma 11(b), there exists a tuple
$\textit{not}\ q({\bf t})$
 then, by Lemma 11(b), there exists a tuple 
 ${\bf r}'$
 in
${\bf r}'$
 in 
 $[{\bf t}]$
 such that
$[{\bf t}]$
 such that 
 $q({\bf r}')\not\in\mathcal{J}$
, and consequently
$q({\bf r}')\not\in\mathcal{J}$
, and consequently 
 $q({\bf r}')\notin\mathcal{J}^{in}$
. If L is a comparison
$q({\bf r}')\notin\mathcal{J}^{in}$
. If L is a comparison 
 $t_1\prec t_2$
 then
$t_1\prec t_2$
 then 
 $\tau^B(L)$
 is
$\tau^B(L)$
 is 
 $$\exists V_1 V_2 (\mathit{val}_{t_1}(V_1) \land \mathit{val}_{t_2}(V_2) \land V_1\prec V_2).$$
$$\exists V_1 V_2 (\mathit{val}_{t_1}(V_1) \land \mathit{val}_{t_2}(V_2) \land V_1\prec V_2).$$
 Since this formula is satisfied by 
 $\mathcal{J}^\uparrow$
, the relation
$\mathcal{J}^\uparrow$
, the relation 
 $\prec$
 holds for a pair
$\prec$
 holds for a pair 
 $(r_1,r_2)$
 of precomputed terms such that
$(r_1,r_2)$
 of precomputed terms such that 
 $\mathit{val}_{t_1}(r_1)$
 and
$\mathit{val}_{t_1}(r_1)$
 and 
 $\mathit{val}_{t_2}(r_2)$
 are satisfied by
$\mathit{val}_{t_2}(r_2)$
 are satisfied by 
 $\mathcal{J}^\uparrow$
. By Lemma 10,
$\mathcal{J}^\uparrow$
. By Lemma 10, 
 $r_1\in[t_1]$
 and
$r_1\in[t_1]$
 and 
 $r_2\in[t_2]$
.
$r_2\in[t_2]$
.
Lemma 14 Let 
 $\Pi$
 be the set of rules of
$\Pi$
 be the set of rules of 
 $\Omega$
.
$\Omega$
.
- (i) The positive dependency graph of  $\Omega$
 for the input $\Omega$
 for the input $(v,\mathcal{J}^{in})$
 is a supergraph of the positive dependency graph of $(v,\mathcal{J}^{in})$
 is a supergraph of the positive dependency graph of $\tau^*(v(\Pi))$
. $\tau^*(v(\Pi))$
.
- (ii) If  $\Omega$
 is locally tight for the input $\Omega$
 is locally tight for the input $(v,\mathcal{J}^{in})$
 then the graph $(v,\mathcal{J}^{in})$
 then the graph $G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
 has no infinite walks. $G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
 has no infinite walks.
Proof (i) Replacing a choice rule 
 $\{p({\bf t})\}\leftarrow\mathit{Body}$
 in
$\{p({\bf t})\}\leftarrow\mathit{Body}$
 in 
 $\Omega$
 by the basic rule
$\Omega$
 by the basic rule 
 $p({\bf t})\leftarrow\mathit{Body}$
 affects neither the positive dependency graph of
$p({\bf t})\leftarrow\mathit{Body}$
 affects neither the positive dependency graph of 
 $\Omega$
 nor the positive dependency graph of
$\Omega$
 nor the positive dependency graph of 
 $\tau^*(v(\Pi))$
. Consequently we can assume, without loss of generality, that
$\tau^*(v(\Pi))$
. Consequently we can assume, without loss of generality, that 
 $\Omega$
 is an io-program without choice rules.
$\Omega$
 is an io-program without choice rules.
 Pick any edge 
 $(p({\bf r}),A)$
 of the (modified) graph
$(p({\bf r}),A)$
 of the (modified) graph 
 $G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
. Then, there is an instance
$G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
. Then, there is an instance 
 $F\to G$
 of the completed sentence obtained by applying
$F\to G$
 of the completed sentence obtained by applying 
 $\tau^*$
 to a basic rule of
$\tau^*$
 to a basic rule of 
 $v(\Pi)$
 such that
$v(\Pi)$
 such that 
 $p({\bf r})\in\mathit{Pos}({G},\mathcal{J}^\uparrow)$
 and
$p({\bf r})\in\mathit{Pos}({G},\mathcal{J}^\uparrow)$
 and 
 $A\in\mathit{Pos}({F},\mathcal{J}^\uparrow)$
. That rule of
$A\in\mathit{Pos}({F},\mathcal{J}^\uparrow)$
. That rule of 
 $v(\Pi)$
 can be written as
$v(\Pi)$
 can be written as 
 \begin{equation} p(v({\bf t}({\bf U})))\leftarrow v(\mathit{Body}({\bf U})), \end{equation}
\begin{equation} p(v({\bf t}({\bf U})))\leftarrow v(\mathit{Body}({\bf U})), \end{equation}
where
 $$ p({\bf t}({\bf U}))\leftarrow \mathit{Body}({\bf U}),$$
$$ p({\bf t}({\bf U}))\leftarrow \mathit{Body}({\bf U}),$$
 is a rule of 
 $\Pi$
, and
$\Pi$
, and 
 $\bf U$
 is the list of its variables. The result of applying
$\bf U$
 is the list of its variables. The result of applying 
 $\tau^*$
 to (38) is
$\tau^*$
 to (38) is 
 $$\forall {\bf U}{\bf V} (\mathit{val}_{v({\bf t}({\bf U}))}({\bf V}) \land \tau^B(v(\mathit{Body}({\bf U}))) \rightarrow p({\bf V})),$$
$$\forall {\bf U}{\bf V} (\mathit{val}_{v({\bf t}({\bf U}))}({\bf V}) \land \tau^B(v(\mathit{Body}({\bf U}))) \rightarrow p({\bf V})),$$
 where 
 $\bf V$
 is a tuple of general variables. Let
$\bf V$
 is a tuple of general variables. Let 
 $\bf u$
,
$\bf u$
, 
 $\bf z$
 be tuples of precomputed terms that are substituted for
$\bf z$
 be tuples of precomputed terms that are substituted for 
 $\bf U$
,
$\bf U$
, 
 $\bf V$
 in the process of forming the instance
$\bf V$
 in the process of forming the instance 
 $F\to G$
. By Lemma 12, that instance can be written as
$F\to G$
. By Lemma 12, that instance can be written as 
 $$\mathit{val}_{v({\bf t}({\bf u}))}(\mathbf{v}) \land \tau^B(v(\mathit{Body}({\bf u}))) \rightarrow p(\mathbf{v}).$$
$$\mathit{val}_{v({\bf t}({\bf u}))}(\mathbf{v}) \land \tau^B(v(\mathit{Body}({\bf u}))) \rightarrow p(\mathbf{v}).$$
 Consequently 
 $p({\bf r})\in\mathit{Pos}({p(\mathbf{v})},\mathcal{J}^\uparrow)$
 and
$p({\bf r})\in\mathit{Pos}({p(\mathbf{v})},\mathcal{J}^\uparrow)$
 and 
 $$A\in\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}(\mathbf{v}) \land \tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).$$
$$A\in\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}(\mathbf{v}) \land \tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).$$
 The first of these conditions implies 
 $\mathbf{v}={\bf r}$
, so that the second can be rewritten as
$\mathbf{v}={\bf r}$
, so that the second can be rewritten as 
 \begin{equation} A\in\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}({\bf r}) \land \tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).\end{equation}
\begin{equation} A\in\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}({\bf r}) \land \tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).\end{equation}
 It follows that 
 $\mathcal{J}^{\uparrow}$
 satisfies
$\mathcal{J}^{\uparrow}$
 satisfies 
 $\mathit{val}_{v({\bf t}({\bf u}))}({\bf r})$
. By Lemma 10, we can conclude that
$\mathit{val}_{v({\bf t}({\bf u}))}({\bf r})$
. By Lemma 10, we can conclude that 
 ${\bf r}\in v({\bf t}({\bf u}))$
. On the other hand, the set
${\bf r}\in v({\bf t}({\bf u}))$
. On the other hand, the set 
 $\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}(\bf r)},\mathcal{J}^\uparrow)$
 is empty, because the formula
$\mathit{Pos}({\mathit{val}_{v({\bf t}({\bf u}))}(\bf r)},\mathcal{J}^\uparrow)$
 is empty, because the formula 
 $\mathit{val}_{v({\bf t}({\bf u}))}({\bf r})$
 does not contain intensional symbols. Consequently (39) implies that
$\mathit{val}_{v({\bf t}({\bf u}))}({\bf r})$
 does not contain intensional symbols. Consequently (39) implies that 
 $$A\in\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).$$
$$A\in\mathit{Pos}({\tau^B(v(\mathit{Body}({\bf u})))},\mathcal{J}^\uparrow).$$
 By Lemma 13, it follows that 
 $(p({\bf r}),A)$
 is an edge of the positive dependency graph of
$(p({\bf r}),A)$
 is an edge of the positive dependency graph of 
 $\Omega$
 for the input
$\Omega$
 for the input 
 $(v,\mathcal{J}^{in})$
.
$(v,\mathcal{J}^{in})$
.
(ii) Immediate from part (i).
 Now we are ready to prove that condition (a) in the statement of Theorem 2 is equivalent to condition (b). The assumption that 
 $\mathcal{P}$
 is an io-model of
$\mathcal{P}$
 is an io-model of 
 $\Omega$
 for an input
$\Omega$
 for an input 
 $(v,\mathcal{I})$
 implies that
$(v,\mathcal{I})$
 implies that 
 $\mathcal{P}^{in}=\mathcal{I}$
. Indeed, that assumption means that
$\mathcal{P}^{in}=\mathcal{I}$
. Indeed, that assumption means that 
 $\mathcal{P}$
 is the set of public atoms of some stable model
$\mathcal{P}$
 is the set of public atoms of some stable model 
 $\mathcal{J}$
 of the program
$\mathcal{J}$
 of the program 
 $v(\Pi)\cup\mathcal{I}$
, where
$v(\Pi)\cup\mathcal{I}$
, where 
 $\Pi$
 is the set of rules of
$\Pi$
 is the set of rules of 
 $\Omega$
. In that program, the facts
$\Omega$
. In that program, the facts 
 $\mathcal{I}$
 are the only rules containing input symbols in the head, so that
$\mathcal{I}$
 are the only rules containing input symbols in the head, so that 
 $\mathcal{J}^{in}=\mathcal{I}$
. Since all input symbols are public, it follows that
$\mathcal{J}^{in}=\mathcal{I}$
. Since all input symbols are public, it follows that 
 $\mathcal{P}^{in}=\mathcal{I}$
. It remains to show that
$\mathcal{P}^{in}=\mathcal{I}$
. It remains to show that 
 \begin{equation}\hbox{$\mathcal{P}$ is an io-model of~$\Omega$ for~$(v,\mathcal{P}^{in})$ iff $\mathcal{P}^\uparrow$ satisfies $v(\mathrm{COMP}[\Omega]),$}\end{equation}
\begin{equation}\hbox{$\mathcal{P}$ is an io-model of~$\Omega$ for~$(v,\mathcal{P}^{in})$ iff $\mathcal{P}^\uparrow$ satisfies $v(\mathrm{COMP}[\Omega]),$}\end{equation}
 under the assumption that 
 $\Omega$
 is locally tight for
$\Omega$
 is locally tight for 
 $(v,\mathcal{P}^{in})$
.
$(v,\mathcal{P}^{in})$
.
 Recall that 
 $\mathrm{COMP}[\Omega]$
 is the second-order sentence
$\mathrm{COMP}[\Omega]$
 is the second-order sentence 
 $\exists P_1 \cdots P_l\,C$
, where C is obtained from the sentence
$\exists P_1 \cdots P_l\,C$
, where C is obtained from the sentence 
 $\mathrm{COMP}[\tau^*\Pi]$
 by replacing the private symbols
$\mathrm{COMP}[\tau^*\Pi]$
 by replacing the private symbols 
 $p_1/n_1,\dots,p_l/n_l$
 of
$p_1/n_1,\dots,p_l/n_l$
 of 
 $\Omega$
 with distinct predicate variables
$\Omega$
 with distinct predicate variables 
 $P_1,\dots,P_l$
. Then
$P_1,\dots,P_l$
. Then 
 $v(\mathrm{COMP}[\Omega])$
 is
$v(\mathrm{COMP}[\Omega])$
 is 
 $\exists P_1 \cdots P_l\,v(C)$
. Hence, the condition in the right-hand side of (40) means that
$\exists P_1 \cdots P_l\,v(C)$
. Hence, the condition in the right-hand side of (40) means that 
 $$\begin{array} l\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\\mathcal{J}^\uparrow \hbox{ satisfies } v(\mathrm{COMP}[\tau^*\Pi]).\end{array}$$
$$\begin{array} l\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\\mathcal{J}^\uparrow \hbox{ satisfies } v(\mathrm{COMP}[\tau^*\Pi]).\end{array}$$
 Note also that 
 $v(\mathrm{COMP}[\tau^*\Pi]) = \mathrm{COMP}[\tau^*(v(\Pi)]$
. Thus the right-hand side of (40) is equivalent to the condition
$v(\mathrm{COMP}[\tau^*\Pi]) = \mathrm{COMP}[\tau^*(v(\Pi)]$
. Thus the right-hand side of (40) is equivalent to the condition 
 \begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\mathcal{J}^\uparrow \hbox{ satisfies } \mathrm{COMP}[\tau^*(v(\Pi))]. \end{aligned} \end{gather}
\begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\mathcal{J}^\uparrow \hbox{ satisfies } \mathrm{COMP}[\tau^*(v(\Pi))]. \end{aligned} \end{gather}
 The condition in the left-hand side of (40) means that 
 $\mathcal{P}$
 is the set of public atoms of some stable model of
$\mathcal{P}$
 is the set of public atoms of some stable model of 
 $v(\Pi) \cup \mathcal{P}^{in}$
. By Theorem 1, this condition can be equivalently reformulated as follows:
$v(\Pi) \cup \mathcal{P}^{in}$
. By Theorem 1, this condition can be equivalently reformulated as follows: 
 \begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ is a stable model of $\tau^*(v(\Pi) \cup \mathcal{P}^{in})$.} \end{aligned} \end{gather}
\begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ is a stable model of $\tau^*(v(\Pi) \cup \mathcal{P}^{in})$.} \end{aligned} \end{gather}
We can further reformulate this condition using the Main Lemma (Section 6) with
- • the signature  $\sigma_0$
 as $\sigma_0$
 as $\sigma$
, $\sigma$
,
- • all comparison symbols viewed as extensional, 
- •  $\mathcal{J}^\uparrow$
 as I, and $\mathcal{J}^\uparrow$
 as I, and
- •  $\tau^*(v(\Pi) \cup \mathcal{P}^{in})$
 as $\tau^*(v(\Pi) \cup \mathcal{P}^{in})$
 as $\Gamma$
. $\Gamma$
.
 The graph 
 $G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)\cup \mathcal{P}^{in}))$
 has no infinite walks, because it is identical to the graph
$G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)\cup \mathcal{P}^{in}))$
 has no infinite walks, because it is identical to the graph 
 $G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
, which has no infinite walks by Lemma 14(ii). Consequently (42) – and so the left-hand side of (40) – is equivalent to the condition:
$G^{sp}_{\mathcal{J}^\uparrow}(\tau^*(v(\Pi)))$
, which has no infinite walks by Lemma 14(ii). Consequently (42) – and so the left-hand side of (40) – is equivalent to the condition: 
 \begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$}. \end{aligned} \end{gather}
\begin{gather} \begin{aligned} &\hbox{for some set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$}. \end{aligned} \end{gather}
Therefore, condition (40) is equivalent to the assertion that conditions (41) and (43) are equivalent to each other. So to prove (40), it is enough to show that
 \begin{gather} \begin{aligned} &\hbox{for every set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi))]$ iff $\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$}. \end{aligned} \end{gather}
\begin{gather} \begin{aligned} &\hbox{for every set~$\mathcal{J}$ obtained from~$\mathcal{P}$ by adding private precomputed atoms,}\\ &\hbox{$\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi))]$ iff $\mathcal{J}^\uparrow$ satisfies $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$}. \end{aligned} \end{gather}
 Formula 
 $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$
 is a conjunction that includes the completed definitions of all input symbols among its conjunctive terms. The interpretation
$\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$
 is a conjunction that includes the completed definitions of all input symbols among its conjunctive terms. The interpretation 
 $\mathcal{J}^\uparrow$
 satisfies these completed definitions, because
$\mathcal{J}^\uparrow$
 satisfies these completed definitions, because 
 $\mathcal{J}^{in}=\mathcal{P}^{in}$
. On the other hand, the remaining conjunctive terms of
$\mathcal{J}^{in}=\mathcal{P}^{in}$
. On the other hand, the remaining conjunctive terms of 
 $\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$
 form the completion
$\mathrm{COMP}[\tau^*(v(\Pi)) \cup \mathcal{P}^{in}]$
 form the completion 
 $\mathrm{COMP}[\tau^*(v(\Pi))]$
 under the assumption that both comparison symbols and the input symbols are considered extensional. Hence, (44) holds.
$\mathrm{COMP}[\tau^*(v(\Pi))]$
 under the assumption that both comparison symbols and the input symbols are considered extensional. Hence, (44) holds.
10 Proof of Theorem 3
 IO-programs 
 $\Omega$
 and
$\Omega$
 and 
 $\Omega'$
 are equivalent to each other under an assumption A iff, for every input
$\Omega'$
 are equivalent to each other under an assumption A iff, for every input 
 $(v,\mathcal{I})$
 from the domain defined by A and every set
$(v,\mathcal{I})$
 from the domain defined by A and every set 
 $\mathcal{P}$
 of precomputed public atoms,
$\mathcal{P}$
 of precomputed public atoms, 
 \begin{gather*} \text{$\mathcal{P}$ is an io-model of~$\Omega$ for~$(v,\mathcal{I})$ iff $\mathcal{P}$ is an io-model of~$\Omega'$ for~$(v,\mathcal{I})$. }\end{gather*}
\begin{gather*} \text{$\mathcal{P}$ is an io-model of~$\Omega$ for~$(v,\mathcal{I})$ iff $\mathcal{P}$ is an io-model of~$\Omega'$ for~$(v,\mathcal{I})$. }\end{gather*}
 Since 
 $\Omega$
 and
$\Omega$
 and 
 $\Omega'$
 are locally tight under assumption A, they both are locally tight for input
$\Omega'$
 are locally tight under assumption A, they both are locally tight for input 
 $(v,\mathcal{I})$
. Hence, by Theorem 2, the above condition is equivalent to:
$(v,\mathcal{I})$
. Hence, by Theorem 2, the above condition is equivalent to: 
 \begin{gather*} \text{ $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega]$ and~$\mathcal{P}^{\mathit{in}} = \mathcal{I}$ iff $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega']$ and~$\mathcal{P}^{\mathit{in}} = \mathcal{I}$. }\end{gather*}
\begin{gather*} \text{ $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega]$ and~$\mathcal{P}^{\mathit{in}} = \mathcal{I}$ iff $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega']$ and~$\mathcal{P}^{\mathit{in}} = \mathcal{I}$. }\end{gather*}
We can further rewrite this condition as
 \begin{gather*} \text{ $\mathcal{P}^{\mathit{in}} = \mathcal{I}$ implies that $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega']$. }\end{gather*}
\begin{gather*} \text{ $\mathcal{P}^{\mathit{in}} = \mathcal{I}$ implies that $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega']$. }\end{gather*}
 Hence, programs 
 $\Omega$
 and
$\Omega$
 and 
 $\Omega'$
 are equivalent to each other under assumption A iff the condition
$\Omega'$
 are equivalent to each other under assumption A iff the condition 
 \begin{gather} \text{ $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega'],$ } \end{gather}
\begin{gather} \text{ $\mathcal{P}^v$ satisfies~$\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega'],$ } \end{gather}
 holds for every input 
 $(v,\mathcal{I})$
 from the domain defined by A and every set
$(v,\mathcal{I})$
 from the domain defined by A and every set 
 $\mathcal{P}$
 of precomputed public atoms such that
$\mathcal{P}$
 of precomputed public atoms such that 
 $\mathcal{P}^{\mathit{in}} = \mathcal{I}$
; equivalently, iff
$\mathcal{P}^{\mathit{in}} = \mathcal{I}$
; equivalently, iff
- (45) holds for every input  $(v,\mathcal{I})$
 such that $(v,\mathcal{I})$
 such that $\mathcal{I}^v$
 satisfies A and every set $\mathcal{I}^v$
 satisfies A and every set $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}^{\mathit{in}} = \mathcal{I}$
; $\mathcal{P}^{\mathit{in}} = \mathcal{I}$
;
equivalently, iff
- (45) holds for every input  $(v,\mathcal{I})$
 and every set $(v,\mathcal{I})$
 and every set $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}^{\mathit{in}} = \mathcal{I}$
 and $\mathcal{P}^{\mathit{in}} = \mathcal{I}$
 and $\mathcal{P}^v$
 satisfies A; $\mathcal{P}^v$
 satisfies A;
equivalently, iff
- (45) holds for every valuation v of PH and every set  $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}$
 of precomputed public atoms such that $\mathcal{P}^v$
 satisfies A; $\mathcal{P}^v$
 satisfies A;
 equivalently, iff for every valuation v of PH and every set 
 $\mathcal{P}$
 of precomputed public atoms,
$\mathcal{P}$
 of precomputed public atoms, 
 $\mathcal{P}^v$
 satisfies the sentence
$\mathcal{P}^v$
 satisfies the sentence 
 \begin{gather*}A \to (\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega']).\end{gather*}
\begin{gather*}A \to (\mathrm{COMP}[\Omega] \leftrightarrow \mathrm{COMP}[\Omega']).\end{gather*}
 It remains to observe that an interpretation of 
 $\sigma_0$
 is standard for PH iff it can be represented in the form
$\sigma_0$
 is standard for PH iff it can be represented in the form 
 $\mathcal{P}^v$
 for some
$\mathcal{P}^v$
 for some 
 $\mathcal{P}$
 and v.
$\mathcal{P}$
 and v.
11 Conclusion
In this paper, we defined when an io-program is considered locally tight for an input, and proved two properties of locally tight programs: io-models can be characterized in terms of completion (Theorem 2), and the anthem-p2p algorithm can be used to verify equivalence (Theorem 3). The local tightness condition is satisfied for many nontight programs that describe dynamic domains.
Theorem 2 can be used also to justify using the anthem algorithm (Fandinno et al. Reference Fandinno, Lifschitz, Lühne and Schaub2020) for verifying a locally tight program with respect to a specification expressed by first-order sentences.
Future work will include extending the anthem-p2p algorithm and Theorem 3 to ASP programs that involve aggregate expressions, using the ideas of Fandinno et al. (Reference Fandinno, Hansen and Lierler2022) and Lifschitz (Reference Lifschitz2022).
Appendix A Many-sorted formulas
A many-sorted signature consists of symbols of three kinds – sorts, function constants, and predicate constants. A reflexive and transitive subsort relation is defined on the set of sorts. A tuple 
 $s_1,\dots,s_n$
 (
$s_1,\dots,s_n$
 (
 $n\geq 0$
) of argument sorts is assigned to every function constant and to every predicate constant; in addition, a value sort is assigned to every function constant. Function constants with
$n\geq 0$
) of argument sorts is assigned to every function constant and to every predicate constant; in addition, a value sort is assigned to every function constant. Function constants with 
 $n=0$
 are called object constants.
$n=0$
 are called object constants.
 We assume that for every sort, an infinite sequence of object variables of that sort is chosen. Terms over a many-sorted signature 
 $\sigma$
 are defined recursively:
$\sigma$
 are defined recursively:
- • object constants and object variables of a sort s are terms of sort s; 
- • if f is a function constant with argument sorts  $s_1,\dots,s_n$
 ( $s_1,\dots,s_n$
 ( $n>0$
) and value sort s, and $n>0$
) and value sort s, and $t_1,\dots,t_n$
 are terms such that the sort of $t_1,\dots,t_n$
 are terms such that the sort of $t_i$
 is a subsort of $t_i$
 is a subsort of $s_i$
 ( $s_i$
 ( $i=1,\dots,n$
), then $i=1,\dots,n$
), then $f(t_1,\dots,t_n)$
 is a term of sort s. $f(t_1,\dots,t_n)$
 is a term of sort s.
 
Atomic formulas over 
 $\sigma$
 are
$\sigma$
 are
- • expressions of the form  $p(t_1,\dots,t_n)$
, where p is a predicate constant and $p(t_1,\dots,t_n)$
, where p is a predicate constant and $t_1,\dots,t_n$
 are terms such that their sorts are subsorts of the argument sorts $t_1,\dots,t_n$
 are terms such that their sorts are subsorts of the argument sorts $s_1,\dots,s_n$
 of p, and $s_1,\dots,s_n$
 of p, and
- • expressions of the form  $t_1=t_2$
, where $t_1=t_2$
, where $t_1$
 and $t_1$
 and $t_2$
 are terms such that their sorts have a common supersort. $t_2$
 are terms such that their sorts have a common supersort.
First-order formulas over 
 $\sigma$
 are formed from atomic formulas and the 0-place connective
$\sigma$
 are formed from atomic formulas and the 0-place connective 
 $\bot$
 (falsity) using the binary connectives
$\bot$
 (falsity) using the binary connectives 
 $\land$
,
$\land$
, 
 $\lor$
,
$\lor$
, 
 $\to$
 and the quantifiers
$\to$
 and the quantifiers 
 $\forall$
,
$\forall$
, 
 $\exists$
. The other connectives are treated as abbreviations:
$\exists$
. The other connectives are treated as abbreviations: 
 $\neg F$
 stands for
$\neg F$
 stands for 
 $F\to\bot$
 and
$F\to\bot$
 and 
 $F\leftrightarrow G$
 stands for
$F\leftrightarrow G$
 stands for 
 $(F\to G)\land (G\to F)$
. First-order sentences are first-order formulas without free variables. The universal closure
$(F\to G)\land (G\to F)$
. First-order sentences are first-order formulas without free variables. The universal closure 
 $\widetilde{\forall} F$
 of a formula F is the sentence
$\widetilde{\forall} F$
 of a formula F is the sentence 
 $\forall{\bf X}\,F$
, where
$\forall{\bf X}\,F$
, where 
 $\bf X$
 is the list of free variables of F.
$\bf X$
 is the list of free variables of F.
 An interpretation I of a signature 
 $\sigma$
 assigns
$\sigma$
 assigns
- • a non-empty domain  $|I|^s$
 to every sort s of I, so that $|I|^s$
 to every sort s of I, so that $|I|^{s_1}\subseteq |I|^{s_2}$
 whenever $|I|^{s_1}\subseteq |I|^{s_2}$
 whenever $s_1$
 is a subsort of $s_1$
 is a subsort of $s_2$
, $s_2$
,
- • a function  $f^I$
 from $f^I$
 from $|I|^{s_1}\times\cdots\times|I|^{s_n}$
 to $|I|^{s_1}\times\cdots\times|I|^{s_n}$
 to $|I|^s$
 to every function constant f with argument sorts $|I|^s$
 to every function constant f with argument sorts $s_1,\dots,s_n$
 and value sort s, and $s_1,\dots,s_n$
 and value sort s, and
- • a Boolean-valued function  $p^I$
 on $p^I$
 on $|I|^{s_1}\times\cdots\times|I|^{s_n}$
 to every predicate constant p with argument sorts $|I|^{s_1}\times\cdots\times|I|^{s_n}$
 to every predicate constant p with argument sorts $s_1,\dots,s_n$
. $s_1,\dots,s_n$
.
If I is an interpretation of a signature 
 $\sigma$
 then by
$\sigma$
 then by 
 $\sigma^I$
 we denote the signature obtained from
$\sigma^I$
 we denote the signature obtained from 
 $\sigma$
 by adding, for every element d of a domain
$\sigma$
 by adding, for every element d of a domain 
 $|I|^s$
, its name
$|I|^s$
, its name 
 $d^*$
 as an object constant of sort s. The interpretation I is extended to
$d^*$
 as an object constant of sort s. The interpretation I is extended to 
 $\sigma^I$
 by defining
$\sigma^I$
 by defining 
 $(d^*)^I=d$
. The value
$(d^*)^I=d$
. The value 
 $t^I$
 assigned by an interpretation I of
$t^I$
 assigned by an interpretation I of 
 $\sigma$
 to a ground term t over
$\sigma$
 to a ground term t over 
 $\sigma^I$
 and the satisfaction relation between an interpretation of
$\sigma^I$
 and the satisfaction relation between an interpretation of 
 $\sigma$
 and a sentence over
$\sigma$
 and a sentence over 
 $\sigma^I$
 are defined recursively, in the usual way. A model of a set
$\sigma^I$
 are defined recursively, in the usual way. A model of a set 
 $\Gamma$
 of sentences is an interpretation that satisfies all members of
$\Gamma$
 of sentences is an interpretation that satisfies all members of 
 $\Gamma$
.
$\Gamma$
.
If 
 $\mathbf{d}$
 is a tuple
$\mathbf{d}$
 is a tuple 
 $d_1,\dots,d_n$
 of elements of domains of I then
$d_1,\dots,d_n$
 of elements of domains of I then 
 $\mathbf{d}^*$
 stands for the tuple
$\mathbf{d}^*$
 stands for the tuple 
 $d_1^*,\dots,d_n^*$
 of their names. If
$d_1^*,\dots,d_n^*$
 of their names. If 
 $\mathbf{t}$
 is a tuple
$\mathbf{t}$
 is a tuple 
 $t_1,\dots,t_n$
 of ground terms then
$t_1,\dots,t_n$
 of ground terms then 
 $\mathbf{t}^I$
 stands for the tuple
$\mathbf{t}^I$
 stands for the tuple 
 $t_1^I,\dots,t_n^I$
 of values assigned to them by I.
$t_1^I,\dots,t_n^I$
 of values assigned to them by I.
Appendix B Stable models of many-sorted theories
The definition of a stable model given below is based on the first-order logic of here-and-there, which was introduced by Pearce and Valverde (Reference Pearce and Valverde2004) and Ferraris et al. (Reference Ferraris, Lee and Lifschitz2011), and then extended to many-sorted formulas (Fandinno and Lifschitz Reference Fandinno and Lifschitz2023).
Consider a many-sorted signature 
 $\sigma$
 with its predicate constants partitioned into intensional and extensional. For any interpretation I of
$\sigma$
 with its predicate constants partitioned into intensional and extensional. For any interpretation I of 
 $\sigma$
,
$\sigma$
, 
 $I^\downarrow$
 stands for the set of atoms of the form
$I^\downarrow$
 stands for the set of atoms of the form 
 $p(\mathbf{d}^*)$
 with intensional p that are satisfied by this interpretation.Footnote 8
$p(\mathbf{d}^*)$
 with intensional p that are satisfied by this interpretation.Footnote 8
 An HT-interpretation of 
 $\sigma$
 is a pair
$\sigma$
 is a pair 
 $\langle \mathcal{H},I\rangle$
, where I is an interpretation of
$\langle \mathcal{H},I\rangle$
, where I is an interpretation of 
 $\sigma$
, and
$\sigma$
, and 
 $\mathcal{H}$
 is a subset of
$\mathcal{H}$
 is a subset of 
 $I^\downarrow$
. (In terms of Kripke models with two sorts, I is the there-world, and
$I^\downarrow$
. (In terms of Kripke models with two sorts, I is the there-world, and 
 $\mathcal{H}$
 describes the intensional predicates in the here-world). The satisfaction relation
$\mathcal{H}$
 describes the intensional predicates in the here-world). The satisfaction relation 
 $\models_{ht}$
 between HT-interpretation
$\models_{ht}$
 between HT-interpretation 
 $\langle \mathcal{H}, I\rangle$
 of
$\langle \mathcal{H}, I\rangle$
 of 
 $\sigma$
 and a sentence F over
$\sigma$
 and a sentence F over 
 $\sigma^I$
 is defined recursively as follows:
$\sigma^I$
 is defined recursively as follows:
- •  $\langle \mathcal{H}, I\rangle \models_{ht} p(\mathbf{t})$
, where p is intensional, if $\langle \mathcal{H}, I\rangle \models_{ht} p(\mathbf{t})$
, where p is intensional, if $p((\mathbf{t}^I)^*)\in \mathcal{H}$
; $p((\mathbf{t}^I)^*)\in \mathcal{H}$
;
- •  $\langle \mathcal{H}, I\rangle \models_{ht} p(\mathbf{t})$
, where p is extensional, if $\langle \mathcal{H}, I\rangle \models_{ht} p(\mathbf{t})$
, where p is extensional, if $I \models p(\mathbf{t})$
; $I \models p(\mathbf{t})$
;
- •  $\langle \mathcal{H}, I\rangle \models_{ht} t_1=t_2$
 if $\langle \mathcal{H}, I\rangle \models_{ht} t_1=t_2$
 if $t_1^I=t_2^I$
; $t_1^I=t_2^I$
;
- •  $\langle \mathcal{H}, I\rangle \not\models_{ht}\bot$
; $\langle \mathcal{H}, I\rangle \not\models_{ht}\bot$
;
- •  $\langle \mathcal{H}, I\rangle \models_{ht} F\land G$
 if $\langle \mathcal{H}, I\rangle \models_{ht} F\land G$
 if $\langle \mathcal{H}, I\rangle \models_{ht} F$
 and $\langle \mathcal{H}, I\rangle \models_{ht} F$
 and $\langle \mathcal{H}, I\rangle \models_{ht} G$
; $\langle \mathcal{H}, I\rangle \models_{ht} G$
;
- •  $\langle \mathcal{H}, I\rangle \models_{ht} F\lor G$
 if $\langle \mathcal{H}, I\rangle \models_{ht} F\lor G$
 if $\langle \mathcal{H}, I\rangle \models_{ht} F$
 or $\langle \mathcal{H}, I\rangle \models_{ht} F$
 or $\langle \mathcal{H}, I\rangle \models_{ht} G$
; $\langle \mathcal{H}, I\rangle \models_{ht} G$
;
- •  $\langle \mathcal{H}, I\rangle \models_{ht} F\to G$
 if $\langle \mathcal{H}, I\rangle \models_{ht} F\to G$
 if- (i)  $\langle \mathcal{H}, I\rangle \not\models_{ht} F$
 or $\langle \mathcal{H}, I\rangle \not\models_{ht} F$
 or $\langle \mathcal{H}, I\rangle \models_{ht} G$
, and $\langle \mathcal{H}, I\rangle \models_{ht} G$
, and
- (ii)  $I \models F\to G$
; $I \models F\to G$
;
 
- •  $\langle \mathcal{H}, I\rangle\models_{ht}\forall X\,F(X)$
 if $\langle \mathcal{H}, I\rangle\models_{ht}\forall X\,F(X)$
 if $\langle \mathcal{H}, I\rangle\models_{ht} F(d^*)$
 for each $\langle \mathcal{H}, I\rangle\models_{ht} F(d^*)$
 for each $d\in|I|^s$
, where s is the sort of X; $d\in|I|^s$
, where s is the sort of X;
- •  $\langle \mathcal{H}, I\rangle\models_{ht}\exists X\,F(X)$
 if $\langle \mathcal{H}, I\rangle\models_{ht}\exists X\,F(X)$
 if $\langle \mathcal{H}, I\rangle\models_{ht} F(d^*)$
 for some $\langle \mathcal{H}, I\rangle\models_{ht} F(d^*)$
 for some $d\in|I|^s$
, where s is the sort of X. $d\in|I|^s$
, where s is the sort of X.
If 
 $\langle \mathcal{H}, I\rangle \models_{ht} F$
 holds, we say that
$\langle \mathcal{H}, I\rangle \models_{ht} F$
 holds, we say that 
 $\langle \mathcal{H}, I\rangle$
 satisfies F and that
$\langle \mathcal{H}, I\rangle$
 satisfies F and that 
 $\langle \mathcal{H}, I\rangle$
 is an HT-model of F. If two formulas have the same HT-models then we say that they are HT-equivalent.
$\langle \mathcal{H}, I\rangle$
 is an HT-model of F. If two formulas have the same HT-models then we say that they are HT-equivalent.
In the following proposition, we collected some properties of this satisfaction relation that can be proved by induction.
Proposition 3
- (a) If  $\langle\mathcal{H},I \rangle\models_{ht} F$
 then $\langle\mathcal{H},I \rangle\models_{ht} F$
 then $I \models F$
. $I \models F$
.
- (b) For any sentence F that does not contain intensional symbols,  $\langle\mathcal{H},I \rangle\models_{ht} F$
 iff $\langle\mathcal{H},I \rangle\models_{ht} F$
 iff ${I\models F}$
. ${I\models F}$
.
- (c) For any subset  $\mathcal{S}$
 of $\mathcal{S}$
 of $\mathcal{H}$
 such that the predicate symbols of its members do not occur in F, $\mathcal{H}$
 such that the predicate symbols of its members do not occur in F, $\langle\mathcal{H} \setminus \mathcal{S}, I\rangle\models_{ht} F$
 iff $\langle\mathcal{H} \setminus \mathcal{S}, I\rangle\models_{ht} F$
 iff $\langle\mathcal{H}, I\rangle\models_{ht} F$
. $\langle\mathcal{H}, I\rangle\models_{ht} F$
.
About a model I of a set 
 $\Gamma$
 of sentences over
$\Gamma$
 of sentences over 
 $\sigma^I$
 we say it is stable if, for every proper subset
$\sigma^I$
 we say it is stable if, for every proper subset 
 $\mathcal{H}$
 of
$\mathcal{H}$
 of 
 $I^\downarrow$
, HT-interpretation
$I^\downarrow$
, HT-interpretation 
 $\langle \mathcal{H},I \rangle$
 does not satisfy
$\langle \mathcal{H},I \rangle$
 does not satisfy 
 $\Gamma$
. In application to finite sets of formulas with a single sort, this definition of a stable model is equivalent to the definition in terms of the operator SM (Ferraris et al. Reference Ferraris, Lee and Lifschitz2011).
$\Gamma$
. In application to finite sets of formulas with a single sort, this definition of a stable model is equivalent to the definition in terms of the operator SM (Ferraris et al. Reference Ferraris, Lee and Lifschitz2011).
We say that I is pointwise stable if, for every element M of 
 $I^\downarrow$
,
$I^\downarrow$
, 
 $\langle I^\downarrow \setminus\{M\},I\rangle$
 does not satisfy
$\langle I^\downarrow \setminus\{M\},I\rangle$
 does not satisfy 
 $\Gamma$
.
$\Gamma$
.
 
  
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
