{"status":"ok","message-type":"work","message-version":"1.0.0","message":{"indexed":{"date-parts":[[2024,9,8]],"date-time":"2024-09-08T02:31:02Z","timestamp":1725762662166},"reference-count":0,"publisher":"EasyChair","content-domain":{"domain":[],"crossmark-restriction":false},"short-container-title":[],"abstract":"LPTP (Logic Program Theorem Prover) is an interactive natural-deduction-based the- orem prover for pure Prolog programs with negation as failure, unification with the occurs check, and a restricted but extensible set of built-in predicates. With LPTP, one can formally prove termination and partial correctness of such Prolog programs. LPTP was designed in the mid 90\u2019s by Robert F. Sta \u0308rk. It is written in ISO-Prolog and comes with an Emacs user-interface.<\/jats:p>From a theoretical point of view, in his publications about LPTP, Sta \u0308rk associates a set of first-order axioms IND(P) to the considered Prolog program P. IND(P) contains the Clark\u2019s equality theory for P, definitions of success, failure and termination for each user-defined logic procedure in P , axioms relating these three points of view, and an axiom schema for proving inductive properties. LPTP is thus a dedicated proof editor where these axioms are hard-wired.<\/jats:p>We propose to explicit these axioms as first-order formulas (FOFs), and apply auto- mated theorem provers to check the property of interest. Using FOF as an intermediary language, we experiment the use of automated theorem provers for Prolog program veri- fication. We evaluate the approach over a benchmark of about 400 properties of Prolog programs from the library available with LPTP. Both the compiler which generates a set of FOF files from a given input Prolog program together with its properties and the benchmark are publicly available.<\/jats:p>","DOI":"10.29007\/c25r","type":"proceedings-article","created":{"date-parts":[[2024,5,27]],"date-time":"2024-05-27T22:10:12Z","timestamp":1716847812000},"page":"137-121","source":"Crossref","is-referenced-by-count":0,"title":["Automated Theorem Proving for Prolog Verification"],"prefix":"10.29007","volume":"18","author":[{"given":"Fred","family":"Mesnard","sequence":"first","affiliation":[]},{"given":"Thierry","family":"Marianne","sequence":"additional","affiliation":[]},{"given":"Etienne","family":"Payet","sequence":"additional","affiliation":[]}],"member":"11545","event":{"name":"LPAR 2024 Complementary Volume"},"container-title":["Kalpa Publications in Computing"],"original-title":[],"deposited":{"date-parts":[[2024,5,27]],"date-time":"2024-05-27T22:10:27Z","timestamp":1716847827000},"score":1,"resource":{"primary":{"URL":"https:\/\/easychair.org\/publications\/paper\/n9Jl"}},"subtitle":[],"short-title":[],"issued":{"date-parts":[[null]]},"references-count":0,"URL":"https:\/\/doi.org\/10.29007\/c25r","relation":{},"ISSN":["2515-1762"],"issn-type":[{"type":"print","value":"2515-1762"}],"subject":[]}}