Detail výsledku

Advanced Automata-based Algorithms for Program Termination Checking

LENGÁL, O.; HEIZMANN, M.; CHEN, Y.; LI, Y.; TSAI, M.; TURRINI, A.; ZHANG, L. Advanced Automata-based Algorithms for Program Termination Checking. In Proceedings of PLDI'18. Philadelphia: Association for Computing Machinery, 2018. p. 135-150. ISBN: 978-1-4503-5698-5.
Typ
článek ve sborníku konference
Jazyk
anglicky
Autoři
Lengál Ondřej, doc. Ing., Ph.D., UITS (FIT)
HEIZMANN, M.
Chen Yu-Fang
LI, Y.
Tsai Ming-Hsien, FIT (FIT)
TURRINI, A.
ZHANG, L.
Abstrakt

In 2014, Heizmann et al. proposed a novel framework for program termination analysis. The analysis starts with a termination proof of a sample path. The path is generalized to
a Büchi automaton (BA) whose language (by construction) represents a set of terminating paths. All these paths can be safely removed from the program. The removal of paths is done using automata difference, implemented via BA complementation and intersection. The analysis constructs in this way a set of BAs that jointly "cover" the behavior of the program, thus proving its termination. An implementation of the approach in Ultimate Automizer won the 1st place in the Termination category of SV-Comp 2017. In this paper, we exploit advanced automata-based algorithms and propose several non-trivial improvements of the framework. To alleviate the complementation computation for BAs---one of the most expensive operations in the framework---, we propose a multi-stage generalization construction. We start with generalizations producing subclasses of BAs (such as deterministic BAs) for which efficient complementation algorithms are known, and proceed to more general classes only if necessary. Particularly, we focus on the quite expressive subclass of semideterministic BAs and provide an improved complementation algorithm for this class. Our experimental evaluation shows that the proposed approach significantly improves the power of termination checking within the Ultimate Automizer framework.

Klíčová slova

automata theory, bug detection, correctness,program logics, software engineering, static analysis, symbolic execution, verification

Rok
2018
Strany
135–150
Sborník
Proceedings of PLDI'18
Konference
ACM SIGPLAN Conference on Programming Language Design and Implementation -- PLDI'18
ISBN
978-1-4503-5698-5
Vydavatel
Association for Computing Machinery
Místo
Philadelphia
DOI
UT WoS
000452469600010
EID Scopus
BibTeX
@inproceedings{BUT155012,
  author="LENGÁL, O. and HEIZMANN, M. and CHEN, Y. and LI, Y. and TSAI, M. and TURRINI, A. and ZHANG, L.",
  title="Advanced Automata-based Algorithms for Program Termination Checking",
  booktitle="Proceedings of PLDI'18",
  year="2018",
  pages="135--150",
  publisher="Association for Computing Machinery",
  address="Philadelphia",
  doi="10.1145/3192366.3192405",
  isbn="978-1-4503-5698-5",
  url="https://www.fit.vut.cz/research/publication/11668/"
}
Soubory
Projekty
Bezpečné a spolehlivé počítačové systémy, VUT, Vnitřní projekty VUT, FIT-S-17-4014, zahájení: 2017-03-01, ukončení: 2020-02-29, ukončen
IT4Innovations excellence in science, MŠMT, Národní program udržitelnosti II, LQ1602, zahájení: 2016-01-01, ukončení: 2020-12-31, ukončen
ROBUST - Verifikace a hledání chyb v pokročilém softwaru, GAČR, Standardní projekty, GA17-12465S, zahájení: 2017-01-01, ukončení: 2019-12-31, ukončen
Výzkumné skupiny
Pracoviště
Nahoru