This work introduces a transformation methodology for functional logic programs based on needed narrowing, the optimal and complete operational principle for modern declarative languages which integrate the best features of functional and logic programming. We provide 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 potentiality of our approach.
Scheda prodotto non validato
Scheda prodotto in fase di analisi da parte dello staff di validazione
|Titolo:||Rules + Strategies for Transforming Lazy Functional Logic Programs|
|Rivista:||THEORETICAL COMPUTER SCIENCE|
|Citazione:||Alpuente, M., Falaschi, M., Moreno, G., & Vidal, G. (2004). Rules + Strategies for Transforming Lazy Functional Logic Programs. THEORETICAL COMPUTER SCIENCE, 311, 479-525.|
|Appare nelle tipologie:||1.1 Articolo in rivista|