AbstractWe develop a natural technique for defining functions in logic, i.e. PROLOG, which directly yields lazy evaluation. Its use does not require any change to the PROLOG interpreter. Function definitions run as PROLOG programs and so run very efficiently. It is possible to combine lazy evaluation with nondeterminism and simulate coroutining. It is also possible to handle infinite data structures and implement networks of communicating processes. We analyze this technique and develop a precise definition of lazy evaluation for lists. For further efficiency we show how to preprocess programs and ensure, using logical variables, that values of expressions once generated are remembered for future access. Finally, we show how to translate pr...
In the recent years a multitude of functional language implementations has been developed, whereby t...
In this paper we present a model of interactive programs in a purely functional style. We exploit l...
We address the problem of producing a trace of the evaluation of a program written in a lazy functio...
AbstractWe develop a natural technique for defining functions in logic, i.e. PROLOG, which directly ...
D We develop a natural technique for defining functions in logic, i.e. PROLOG, which directly yields...
AbstractThere are several proposals for extending Prolog with functional capabilities. The basic ide...
Nondeterminism and partially instantiated data structures give logic programming expressive power b...
Abstract. In this paper, we present a high-level implementation of lazy functional logic programs by...
Functional languages can be enriched with logic variables to provide new computational features suc...
Certain aspects of functional programming provide syntactic convenience, such as having a designated...
Lazy evaluation is an evaluation strategy in programming languages. Lazy evaluation delays the evalu...
AbstractThis paper is based on a recently developed technique to build debugging tools for lazy func...
We propose an embedding of logic programming into lazy functional programming in which each predicat...
Abstract: We propose an embedding of logic programming into lazy functional programming in which eac...
AbstractWe discuss the use of the lazy evaluation scheme as coding tool in some algebraic manipulati...
In the recent years a multitude of functional language implementations has been developed, whereby t...
In this paper we present a model of interactive programs in a purely functional style. We exploit l...
We address the problem of producing a trace of the evaluation of a program written in a lazy functio...
AbstractWe develop a natural technique for defining functions in logic, i.e. PROLOG, which directly ...
D We develop a natural technique for defining functions in logic, i.e. PROLOG, which directly yields...
AbstractThere are several proposals for extending Prolog with functional capabilities. The basic ide...
Nondeterminism and partially instantiated data structures give logic programming expressive power b...
Abstract. In this paper, we present a high-level implementation of lazy functional logic programs by...
Functional languages can be enriched with logic variables to provide new computational features suc...
Certain aspects of functional programming provide syntactic convenience, such as having a designated...
Lazy evaluation is an evaluation strategy in programming languages. Lazy evaluation delays the evalu...
AbstractThis paper is based on a recently developed technique to build debugging tools for lazy func...
We propose an embedding of logic programming into lazy functional programming in which each predicat...
Abstract: We propose an embedding of logic programming into lazy functional programming in which eac...
AbstractWe discuss the use of the lazy evaluation scheme as coding tool in some algebraic manipulati...
In the recent years a multitude of functional language implementations has been developed, whereby t...
In this paper we present a model of interactive programs in a purely functional style. We exploit l...
We address the problem of producing a trace of the evaluation of a program written in a lazy functio...