Chapter

Functional and Logic Programming

Volume 1722 of the series Lecture Notes in Computer Science pp 147-162

A Transformation System for Lazy Functional Logic Programs

  • María AlpuenteAffiliated withDSIC, UPV
  • , Moreno FalaschiAffiliated withDip. Mat. e Informatica, U. Udine
  • , Ginés MorenoAffiliated withDep. Informática, UCLM
  • , Germán VidalAffiliated withDSIC, UPV

* Final gross prices may vary according to local VAT.

Get Access

Abstract

Needed narrowing is a complete operational principle for modern declarative languages which integrate the best features of (lazy) functional and logic programming. We define a transformation methodology for functional logic programs based on needed narrowing. We provide (strong) correctness results for the transformation system w.r.t. the set of computed values and answer substitutions and show that the prominent properties of needed narrowing -namely, the optimality w.r.t. the length of derivations and the number of computed solutions- carry over to the transformation process and the transformed programs. We illustrate the power of the system by taking on in our setting two well-known transformation strategies (composition and tupling). We also provide an implementation of the transformation system which, by means of some experimental results, highlights the benefits of our approach.