Back to Search Start Over

Description and Optimization of Abstract Machines in a Dialect of Prolog

Authors :
Morales, Jose F.
Carro, Manuel
Hermenegildo, Manuel
Source :
Theory and Practice of Logic Programming 16 (2016) 1-58
Publication Year :
2014

Abstract

In order to achieve competitive performance, abstract machines for Prolog and related languages end up being large and intricate, and incorporate sophisticated optimizations, both at the design and at the implementation levels. At the same time, efficiency considerations make it necessary to use low-level languages in their implementation. This makes them laborious to code, optimize, and, especially, maintain and extend. Writing the abstract machine (and ancillary code) in a higher-level language can help tame this inherent complexity. We show how the semantics of most basic components of an efficient virtual machine for Prolog can be described using (a variant of) Prolog. These descriptions are then compiled to C and assembled to build a complete bytecode emulator. Thanks to the high level of the language used and its closeness to Prolog, the abstract machine description can be manipulated using standard Prolog compilation and optimization techniques with relative ease. We also show how, by applying program transformations selectively, we obtain abstract machine implementations whose performance can match and even exceed that of state-of-the-art, highly-tuned, hand-crafted emulators.<br />Comment: 56 pages, 46 figures, 5 tables, To appear in Theory and Practice of Logic Programming (TPLP)

Details

Database :
arXiv
Journal :
Theory and Practice of Logic Programming 16 (2016) 1-58
Publication Type :
Report
Accession number :
edsarx.1411.5573
Document Type :
Working Paper
Full Text :
https://doi.org/10.1017/S1471068414000672