An Optimizing Compiler for Batches of Temporal Logic Formulas
dc.contributor.author | Ezick, James | en_US |
dc.date.accessioned | 2007-04-04T19:21:22Z | |
dc.date.available | 2007-04-04T19:21:22Z | |
dc.date.issued | 2003-09-05 | en_US |
dc.description.abstract | Model checking based on validating temporal logic formulas has proven practical and effective for numerous applications from verifying hardware designs to proving the correctness of software. As systems based on this approach have become more mainstream, a need has arisen to deal effectively with large batches of formulas over a common model. Presently, most systems validate formulas one at a time, with little or no interaction between validation of separate formulas. This is the case despite the fact that for a wide range of applications a certain level of redundancy between domain-related formulas can be anticipated. This paper presents an optimizing compiler for batches of temporal logic formulas. A component of the Carnauba Model Checking System, this compiler addresses the need to handle batches of temporal logic formulas by leveraging the framework common to optimizing programming language compilers. Just as a traditional optimizing compiler attempts to exploit redundancy and other solvable properties in programs to reduce the demand on a runtime system, this compiler exploits similar properties in groups of formulas to reduce the demand on a model checking engine. Optimizations are performed via a set of distinct, interchangeable optimization passes operating on a common intermediate representation. The intermediate representation is capable of representing formulas over the full modal mu-calculus, and the optimization techniques are applicable to any temporal logic that can be translated into the modal mu-calculus. The compiler offers a unified framework for expressing well understood single-formula optimizations as well as numerous inter-formula optimizations that capitalize on redundancy and logical implication. The result is a system that, when applied to a potentially heterogeneous collection of formulas over a common problem domain, is able to measurably reduce the time and space requirements of the subsequent model checking engine. | en_US |
dc.format.extent | 288814 bytes | |
dc.format.mimetype | application/postscript | |
dc.identifier.citation | http://techreports.library.cornell.edu:8081/Dienst/UI/1.0/Display/cul.cis/TR2003-1909 | en_US |
dc.identifier.uri | https://hdl.handle.net/1813/5621 | |
dc.language.iso | en_US | en_US |
dc.publisher | Cornell University | en_US |
dc.subject | computer science | en_US |
dc.subject | technical report | en_US |
dc.title | An Optimizing Compiler for Batches of Temporal Logic Formulas | en_US |
dc.type | technical report | en_US |
Files
Original bundle
1 - 1 of 1