中文

Composing Programs in a Rewriting Logic for Declarative Programming

计算机科学中的逻辑 2007-05-23 v1 编程语言

摘要

Constructor-Based Conditional Rewriting Logic is a general framework for integrating first-order functional and logic programming which gives an algebraic semantics for non-deterministic functional-logic programs. In the context of this formalism, we introduce a simple notion of program module as an open program which can be extended together with several mechanisms to combine them. These mechanisms are based on a reduced set of operations. However, the high expressiveness of these operations enable us to model typical constructs for program modularization like hiding, export/import, genericity/instantiation, and inheritance in a simple way. We also deal with the semantic aspects of the proposal by introducing an immediate consequence operator, and studying several alternative semantics for a program module, based on this operator, in the line of logic programming: the operator itself, its least fixpoint (the least model of the module), the set of its pre-fixpoints (term models of the module), and some other variations in order to find a compositional and fully abstract semantics wrt the set of operations and a natural notion of observability.

关键词

引用

@article{arxiv.cs/0203006,
  title  = {Composing Programs in a Rewriting Logic for Declarative Programming},
  author = {Juan M. Molina and Ernesto Pimentel},
  journal= {arXiv preprint arXiv:cs/0203006},
  year   = {2007}
}

备注

47 pages. A shorter version (33 pages) will appear in the Journal of Theory and Practice of Logic Programming