Relační verifikace programů s celočíselnými daty

but.jazykangličtina (English)
but.programVýpočetní technika a informatikacs
but.resultpráce byla úspěšně obhájenacs
dc.contributor.advisorVojnar, Tomášen
dc.contributor.authorKonečný, Filipen
dc.contributor.refereeBouajjani, Ahmeden
dc.contributor.refereeJančar, Petren
dc.date.createdcs
dc.description.abstractTato práce představuje nové metody pro verifikaci programů pracujících s neomezenými celočíslenými proměnnými, konkrétně metody pro analýzu dosažitelnosti a~konečnosti. Většina těchto metod je založena na akceleračních technikách, které počítají tranzitivní uzávěry cyklů programu. V práci je nejprve představen algoritmus pro akceleraci několika tříd celočíselných relací. Tento algoritmus je až o čtyři řády rychlejší než existující techniky. Z teoretického hlediska práce dokazuje, že uvažované třídy relací jsou periodické a~poskytuje tudíž jednotné řešení prolému akcelerace. Práce dále představuje semi-algoritmus pro analýzu dosažitelnosti celočíselných programů, který sleduje relace mezi proměnnými programu a~aplikuje akcelerační techniky za účelem modulárního výpočtu souhrnů procedur. Dále je v práci navržen alternativní algoritmus pro analýzu dosažitelnosti, který integruje predikátovou abstrakci s accelerací s cílem zvýšit pravděpodobnost konvergence výpočtu. Provedené experimenty ukazují, že oba algoritmy lze úspěšně aplikovat k verifikaci programů, na kterých předchozí metody selhávaly. Práce se rovněž zabývá problémem konečnosti běhu programů a~dokazuje, že tento problém je rozhodnutelný pro několik tříd celočíselných relací. Pro některé z těchto tříd relací je v práci navržen algoritmus, který v polynomiálním čase vypočítá množinu všech konfigurací programu, z nichž existuje nekonečný běh. Tento algoritmus je integrován do metody, která analyzuje konečnost běhů celočíselných programů. Efektivnost této metody je demonstrována na několika netriviálních celočíselných programech.en
dc.description.abstractThis work presents novel methods for verification of reachability and termination properties of programs that manipulate unbounded integer data. Most of these methods are based on acceleration techniques which compute transitive closures of program loops. We first present an algorithm that accelerates several classes of integer relations and show that the new method performs up to four orders of magnitude better than the previous ones. On the theoretical side, our framework provides a common solution to the acceleration problem by proving that the considered classes of relations are periodic. Subsequently, we introduce a semi-algorithmic reachability analysis technique that tracks relations between variables of integer programs and applies the proposed acceleration algorithm to compute summaries of procedures in a modular way. Next, we present an alternative approach to reachability analysis that integrates predicate abstraction with our acceleration techniques to increase the likelihood of convergence of the algorithm. We evaluate these algorithms and show that they can handle a number of complex integer programs where previous approaches failed. Finally, we study the termination problem for several classes of program loops and show that it is decidable. Moreover, for some of these classes, we design a polynomial time algorithm that computes the exact set of program configurations from which nonterminating runs exist. We further integrate this algorithm into a semi-algorithmic method that analyzes termination of integer programs, and show that the resulting technique can verify termination properties of several non-trivial integer programs.cs
dc.description.markPcs
dc.identifier.citationKONEČNÝ, F. Relační verifikace programů s celočíselnými daty [online]. Brno: Vysoké učení technické v Brně. Fakulta informačních technologií. .cs
dc.identifier.other99808cs
dc.identifier.urihttp://hdl.handle.net/11012/63265
dc.language.isoencs
dc.publisherVysoké učení technické v Brně. Fakulta informačních technologiícs
dc.rightsStandardní licenční smlouva - přístup k plnému textu bez omezenícs
dc.subjectprogramy s celočíselnými datyen
dc.subjectčítačové automatyen
dc.subjectanalýza dosažitelnostien
dc.subjectanalýza konečnostien
dc.subjectakceleraceen
dc.subjecttranzitivní uzávěryen
dc.subjectsouhrny proceduren
dc.subjectrekurentní množinyen
dc.subjectvstupní podmínky pro konečnosten
dc.subjectprograms with integerscs
dc.subjectcounter automatacs
dc.subjectreachability analysiscs
dc.subjecttermination analysiscs
dc.subjectaccelerationcs
dc.subjecttransitive closurescs
dc.subjectprocedure summariescs
dc.subjectrecurrent setscs
dc.subjecttermination preconditionscs
dc.titleRelační verifikace programů s celočíselnými datyen
dc.title.alternativeRelational Verification of Programs with Integer Datacs
dc.typeTextcs
dc.type.driverdoctoralThesisen
dc.type.evskpdizertační prácecs
dcterms.modified2020-05-10-17:46:41cs
eprints.affiliatedInstitution.facultyFakulta informačních technologiícs
sync.item.dbid99808en
sync.item.dbtypeZPen
sync.item.insts2025.03.27 12:11:40en
sync.item.modts2025.01.17 10:38:39en
thesis.disciplineVýpočetní technika a informatikacs
thesis.grantorVysoké učení technické v Brně. Fakulta informačních technologií. Ústav inteligentních systémůcs
thesis.levelDoktorskýcs
thesis.namePh.D.cs
Files
Original bundle
Now showing 1 - 5 of 6
Loading...
Thumbnail Image
Name:
final-thesis.pdf
Size:
1.32 MB
Format:
Adobe Portable Document Format
Description:
final-thesis.pdf
Loading...
Thumbnail Image
Name:
thesis-1.pdf
Size:
263.45 KB
Format:
Adobe Portable Document Format
Description:
thesis-1.pdf
Loading...
Thumbnail Image
Name:
Posudek-Vedouci prace-300_s1.pdf
Size:
2.18 MB
Format:
Adobe Portable Document Format
Description:
Posudek-Vedouci prace-300_s1.pdf
Loading...
Thumbnail Image
Name:
Posudek-Oponent prace-300_o1.pdf
Size:
494.23 KB
Format:
Adobe Portable Document Format
Description:
Posudek-Oponent prace-300_o1.pdf
Loading...
Thumbnail Image
Name:
Posudek-Oponent prace-300_o2.pdf
Size:
2.22 MB
Format:
Adobe Portable Document Format
Description:
Posudek-Oponent prace-300_o2.pdf
Collections