Synthesis of positive logic programs for checking a class of definitions with infinite quantification (Q2629858): Difference between revisions

From MaRDI portal
Importer (talk | contribs)
Created a new Item
 
Import241208061232 (talk | contribs)
Normalize DOI.
 
(8 intermediate revisions by 5 users not shown)
Property / DOI
 
Property / DOI: 10.1016/j.ic.2016.06.014 / rank
Normal rank
 
Property / describes a project that uses
 
Property / describes a project that uses: SIMPLIFY / rank
 
Normal rank
Property / describes a project that uses
 
Property / describes a project that uses: Eiffel / rank
 
Normal rank
Property / describes a project that uses
 
Property / describes a project that uses: JML / rank
 
Normal rank
Property / describes a project that uses
 
Property / describes a project that uses: Spec# / rank
 
Normal rank
Property / MaRDI profile type
 
Property / MaRDI profile type: MaRDI publication profile / rank
 
Normal rank
Property / full work available at URL
 
Property / full work available at URL: https://doi.org/10.1016/j.ic.2016.06.014 / rank
 
Normal rank
Property / OpenAlex ID
 
Property / OpenAlex ID: W2439147558 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Logic programming and negation: A survey / rank
 
Normal rank
Property / cites work
 
Property / cites work: Program Development in Computational Logic / rank
 
Normal rank
Property / cites work
 
Property / cites work: Taking Satisfiability to the Next Level with Z3 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Adding metatheoretic facilities to first-order theories / rank
 
Normal rank
Property / cites work
 
Property / cites work: A transformational approach to negation in logic programming / rank
 
Normal rank
Property / cites work
 
Property / cites work: The calculus of constructions / rank
 
Normal rank
Property / cites work
 
Property / cites work: Simplify: a theorem prover for program checking / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4144755 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3992667 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4707743 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Integrated Formal Methods / rank
 
Normal rank
Property / cites work
 
Property / cites work: Solving Quantified Verification Conditions Using Satisfiability Modulo Theories / rank
 
Normal rank
Property / cites work
 
Property / cites work: Lifting abstract interpreters to quantified logical domains / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3925859 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Derivation of Logic Programs / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3339245 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3355225 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4124327 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4024014 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3690194 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4855375 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q2751358 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q3996676 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Synthesis and transformation of logic programs using unfold/fold proofs / rank
 
Normal rank
Property / cites work
 
Property / cites work: Q4707742 / rank
 
Normal rank
Property / cites work
 
Property / cites work: Unfolding--definition--folding, in this order, for avoiding unnecessary variables in logic programs / rank
 
Normal rank
Property / cites work
 
Property / cites work: Completed logic programs and their consistency / rank
 
Normal rank
Property / cites work
 
Property / cites work: Equivalence-preserving first-order unfold/fold transformation systems / rank
 
Normal rank
Property / cites work
 
Property / cites work: First order compiler: A deterministic logic program synthesis algorithm / rank
 
Normal rank
Property / cites work
 
Property / cites work: Unfold⧸fold transformation of general logic programs for the well-founded semantics / rank
 
Normal rank
Property / cites work
 
Property / cites work: From program verification to program synthesis / rank
 
Normal rank
Property / cites work
 
Property / cites work: SWI-Prolog / rank
 
Normal rank
Property / DOI
 
Property / DOI: 10.1016/J.IC.2016.06.014 / rank
 
Normal rank
links / mardi / namelinks / mardi / name
 

Latest revision as of 11:34, 19 December 2024

scientific article
Language Label Description Also known as
English
Synthesis of positive logic programs for checking a class of definitions with infinite quantification
scientific article

    Statements

    Synthesis of positive logic programs for checking a class of definitions with infinite quantification (English)
    0 references
    7 July 2016
    0 references
    The framework is based on typed first-order logic theories such as the following: Types: {\parindent=0.7cm\begin{itemize}\item[--] Nat generated by \(\mathrm{zero}:\rightarrow\mathrm{Nat}\quad\mathrm{succ}:\mathrm{Nat}\rightarrow\mathrm{Nat}\) \item[--] Seq generated by \(\mathrm{empty}:\rightarrow\mathrm{Seq}\quad\mathrm{succ}:\mathrm{Nat}\times\mathrm{Seq}\rightarrow\mathrm{Seq}\) \end{itemize}} Predicates: \(\mathrm{id}:\mathrm{Nat}\times\mathrm{Nat}\) axiomatised as: {\parindent=0.7cm\begin{itemize}\item[--] \(\mathrm{id}(\mathrm{zero},\mathrm{zero})\Leftrightarrow \mathrm{true}\) \item[--] \(\forall(\mathrm{id}(\mathrm{succ}(X),\mathrm{zero})\Leftrightarrow\mathrm{false})\) \item[--] \(\forall(\mathrm{id}(\mathrm{zero},\mathrm{succ}(Y)\Leftrightarrow\mathrm{false})\) \item[--] \(\forall(\mathrm{id}(\mathrm{succ}(X),\mathrm{succ}(Y))\Leftrightarrow\mathrm{id}(X,Y))\) \end{itemize}} \(\mathrm{member}:\mathrm{Nat}\times\mathrm{Seq}\) axiomatised as: {\parindent=0.7cm\begin{itemize}\item[--] \(\forall(\mathrm{member}(E,\mathrm{empty})\Leftrightarrow\mathrm{false})\) \item[--] \(\forall(\mathrm{member}(E,\mathrm{seq}(X,Y ))\Leftrightarrow\mathrm{id}(E,X)\vee\mathrm{member}(E,Y ))\) \end{itemize}} The authors consider \textit{assertion definitions} of the form \(\forall X(r(X)\Leftrightarrow Q Y R(X,Y))\) where \(r\) is the defined relation, \(Q\) is a quantifier, and \(R\) is the defining relation, namely, a quantifier-free formula in the language of the typed first-order logic theory. For example, the following is an assertion definition for the subset relation: \[ \forall L,S(\mathrm{subset}(L,S)\Leftrightarrow\forall E(\mathrm{member}(E,L)\Rightarrow\mathrm{member}(E,S))) \] The purpose of the paper is a method to synthesise a positive logic program for checking assertions of the form \(r(X)\theta\), where \(\theta\) is a ground substitution for \(X\), that depends on the quantifier \(Q\) in such a way that if \(Q\) is \(\forall\) then the program searches for refutations, whereas if \(Q\) is \(\exists\) then the program searches for proofs. The method satisfies both key requirements: {\parindent=0.7cm\begin{itemize}\item[--] the synthesis process terminates after a finite amount of transformation steps; \item[--] the synthesised program preserves total correctness w.r.t. the class of goals of the form \(\Leftarrow r(X,Y)\theta\). \end{itemize}} With the example of the subset relation, the synthesised program is: \[ \begin{aligned} \forall(\mathrm{subset}(L,S) \Leftarrow \mathrm{subset}_1(E,L,S))\\ \forall(\mathrm{subset}_1(E,\mathrm{seq}(X,Y ),S) \Leftarrow \mathrm{subset}_2(E,S)\wedge \mathrm{subset}_3(E,X))\\ \forall(\mathrm{subset}_1(E,\mathrm{seq}(X,Y ),S)\Leftarrow \mathrm{subset}_1(E,Y ,S)\wedge \mathrm{subset}_4(E,X))\\ \forall(\mathrm{subset}_1(E,\mathrm{empty},S) \Leftarrow \mathrm{subset}_5(E,S))\\ \forall(\mathrm{subset}_2(E,\mathrm{seq}(X,Y )) \Leftarrow \mathrm{subset}_2(E,Y )\wedge \mathrm{subset}_4(E,X))\\ \forall(\mathrm{subset}_2(E,\mathrm{empty}) \Leftarrow \mathrm{subset}_7)\\ \mathrm{subset}_3(\mathrm{zero},\mathrm{zero}) \Leftarrow \mathrm{subset}_9\\ \forall(\mathrm{subset}_3(\mathrm{succ}(X),\mathrm{succ}(Y )) \Leftarrow \mathrm{subset}_3(X,Y ))\\ \forall(\mathrm{subset}_4(\mathrm{zero},\mathrm{succ}(Y )) \Leftarrow \mathrm{subset}_9)\\ \forall(\mathrm{subset}_4(\mathrm{succ}(X),\mathrm{succ}(Y )) \Leftarrow \mathrm{subset}_4(X,Y ))\\ \forall(\mathrm{subset}_4(\mathrm{succ}(X),\mathrm{zero}) \Leftarrow \mathrm{subset}_9)\\ \forall(\mathrm{subset}_5(E,\mathrm{seq}(X,Y )) \Leftarrow \mathrm{subset}_5(E,Y )\wedge \mathrm{subset}_4(E,X))\\ \mathrm{subset}_7 \Leftarrow\\ \mathrm{subset}_9 \Leftarrow\end{aligned} \] following a procedure that consists of 6 steps, with intermediate formulas generated on the way, in particular: \[ \begin{aligned}\forall E,L,S(\mathrm{subset}_1(E,L,S)\Leftrightarrow(\mathrm{member}(E,L)\wedge\neg\mathrm{member}(E,S)))\\ \forall(\mathrm{subset}_2(X,Y )\Leftrightarrow\mathrm{true}\wedge\neg\mathrm{member}(X,Y ))\\ \forall(\mathrm{subset}_3(X,Y )\Leftrightarrow\mathrm{id}(X,Y ))\\ \forall(\mathrm{subset}_4(X,Y )\Leftrightarrow\neg\mathrm{id}(X,Y ))\\ \forall(\mathrm{subset}_5(X,Y )\Leftrightarrow\mathrm{false}\wedge\neg\mathrm{member}(X,Y ))\\ \mathrm{subset}_6\Leftrightarrow\mathrm{false}\wedge\neg\mathrm{false}\\ \mathrm{subset}_7\Leftrightarrow\mathrm{true}\wedge\neg\mathrm{false}\\ \mathrm{subset}_8\Leftrightarrow\mathrm{true}\wedge\neg\mathrm{true}\\ \mathrm{subset}_9\Leftrightarrow\mathrm{true}\\ \mathrm{subset}_{10}\Leftrightarrow\neg\mathrm{true}\end{aligned} \] The method has been tested with many other assertion definitions, listed in the appendix, together with the proofs of termination and correctness.
    0 references
    0 references
    program assertion
    0 references
    logic program
    0 references
    program synthesis
    0 references
    unfold/fold transformation
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references
    0 references

    Identifiers

    0 references
    0 references
    0 references
    0 references
    0 references
    0 references