中文

A General Framework For Lazy Functional Logic Programming With Algebraic Polymorphic Types

编程语言 2007-05-23 v1

摘要

We propose a general framework for first-order functional logic programming, supporting lazy functions, non-determinism and polymorphic datatypes whose data constructors obey a set C of equational axioms. On top of a given C, we specify a program as a set R of C-based conditional rewriting rules for defined functions. We argue that equational logic does not supply the proper semantics for such programs. Therefore, we present an alternative logic which includes C-based rewriting calculi and a notion of model. We get soundness and completeness for C-based rewriting w.r.t. models, existence of free models for all programs, and type preservation results. As operational semantics, we develop a sound and complete procedure for goal solving, which is based on the combination of lazy narrowing with unification modulo C. Our framework is quite expressive for many purposes, such as solving action and change problems, or realizing the GAMMA computation model.

关键词

引用

@article{arxiv.cs/0404050,
  title  = {A General Framework For Lazy Functional Logic Programming With Algebraic Polymorphic Types},
  author = {Puri Arenas-Sanchez and Mario Rodriguez-Artalejo},
  journal= {arXiv preprint arXiv:cs/0404050},
  year   = {2007}
}

备注

Appeared in Theory and Practice of Logic Programming, vol. 1, no. 2, 2001