Design and implementation of practical constraint logic programming systems:

Abstract: "The Constraint Logic Programming (CLP) scheme, developed by Jaffar and Lassez, defines a class of rule-based constraint programming languages. These generalize traditional logic programming languages (like Prolog) by replacing the basic operational step, unification, with constraint...

Ausführliche Beschreibung

Gespeichert in:
Bibliographische Detailangaben
1. Verfasser: Michaylov, Spiro (VerfasserIn)
Format: Buch
Sprache:English
Veröffentlicht: Pittsburgh, PA School of Computer Science, Carnegie Mellon Univ. 1992
Schriftenreihe:School of Computer Science <Pittsburgh, Pa.>: CMU-CS 1992,168
Schlagworte:
Zusammenfassung:Abstract: "The Constraint Logic Programming (CLP) scheme, developed by Jaffar and Lassez, defines a class of rule-based constraint programming languages. These generalize traditional logic programming languages (like Prolog) by replacing the basic operational step, unification, with constraint solving. While CLP languages have a tremendous advantage in terms of expressive power, they must be shown to be amenable to practical implementations. This thesis describes a systematic approach to the design and implementation of practical CLP systems. The approach is evaluated with respect to two major objectives. First, the Prolog subset of the languages must be executed with essentially the efficiency of an equivalent Prolog system
Second, the cost of constraint solving must be commensurate with the complexity of the constraints arising. The language CLP(R), whose domain is uninterpreted functors over real numbers, is the central case study. First, the design of CLP(R) is discussed in relation to programming methodology. The discussion of implementation begins with an interpreter that achieves the efficiency of equivalent Prolog interpreters, and meets many of the basic efficiency requirements for constraint solving. Many of the principles applied in the interpreter are then used to develop an abstract machine for CLP(R), leading to a compiler-based system achieving performance comparable to modern Prolog compilers
Furthermore, it is shown how this technology can be extended so that the efficiency of CLP(R) approaches that of imperative programming languages. Finally, to demonstrate the wider applicability of the techniques developed, it is shown how they can be used to design and implement a version of Elf, a language with equality constraints over [lambda]-expressions with dependent types.
Beschreibung:Zugl.: Pittsburgh, Pa., Univ., Diss., 1992
Beschreibung:XIV, 228 S. graph. Darst.