Partial evaluation of functional logic programs

被引:47
|
作者
Alpuente, M
Falaschi, M
Vidal, G
机构
[1] Univ Politecn Valencia, Dept Sistemas Informat & Computac, Valencia 46022, Spain
[2] Univ Udine, I-33100 Udine, Italy
关键词
languages; performance; theory; conditional term-rewriting systems; integration of functional and logic programming; narrowing strategies; partial evaluation;
D O I
10.1145/291891.291896
中图分类号
TP31 [计算机软件];
学科分类号
081202 ; 0835 ;
摘要
Languages that integrate functional and logic programming with a complete operational semantics are based on narrowing, a unification-based goal-solving mechanism which subsumes the reduction principle of functional languages and the resolution principle of logic languages. In this article, we present a partial evaluation scheme for functional logic languages based on an automatic unfolding algorithm which builds narrowing trees. The method is formalized within the theoretical framework established by Lloyd and Shepherdson for the partial deduction of logic programs, which we have generalized for dealing with functional computations. A generic specialization algorithm is proposed which does not depend on the eager or lazy nature of the narrower being used. To the best of our knowledge, this is the first generic algorithm for the specialization of functional logic programs. We study the semantic properties of the transformation and the conditions under which the technique terminates, is sound and complete, and is generally applicable to a wide class of programs. We also discuss the relation to work on partial evaluation in functional programming, term-rewriting systems, and logic programming. Finally, we present some experimental results with an implementation of the algorithm which show in practice that the narrowing-driven partial evaluator effectively combines the propagation of partial data structures (by means of logical variables and unification) with better opportunities for optimization (thanks to the functional dimension).
引用
收藏
页码:768 / 844
页数:77
相关论文
共 50 条
  • [41] Free Theorems for Functional Logic Programs
    Christiansen, Jan
    Seidel, Daniel
    Voigtlaender, Janis
    [J]. PLPV'10: PROCEEDINGS OF THE 2010 ACM SIGPLAN WORKSHOP ON PROGRAMMING LANGUAGES MEETS PROGRAM VERIFICATION, 2010, : 39 - 48
  • [42] Monadic logic programs and functional complexity
    Matos, AB
    [J]. THEORETICAL COMPUTER SCIENCE, 1997, 176 (1-2) : 175 - 204
  • [43] PARTIAL EVALUATION IN LOGIC PROGRAMMING
    LLOYD, JW
    SHEPHERDSON, JC
    [J]. JOURNAL OF LOGIC PROGRAMMING, 1991, 11 (3-4): : 217 - 242
  • [45] A framework for goal-directed bottom-up evaluation of functional logic programs
    Almendros-Jiménez, JM
    Becerra-Terón, A
    [J]. FUNCTIONAL AND LOGIC PROGRAMMING, PROCEEDINGS, 2001, 2024 : 153 - 169
  • [46] Incremental evaluation of tabled logic programs
    Saha, D
    Ramakrishnan, CR
    [J]. LOGIC PROGRAMMING, PROCEEDINGS, 2003, 2916 : 392 - 406
  • [47] An automatic partial deduction system for constraint logic programs
    Tao, Y
    Grosky, WI
    Liu, CN
    [J]. NINTH IEEE INTERNATIONAL CONFERENCE ON TOOLS WITH ARTIFICIAL INTELLIGENCE, PROCEEDINGS, 1997, : 149 - 156
  • [48] Specialization of inductively sequential functional logic programs
    Alpuente, M
    Hanus, M
    Lucas, S
    Vidal, G
    [J]. ACM SIGPLAN NOTICES, 1999, 34 (09) : 273 - 283
  • [49] A transformation system for lazy functional logic programs
    Alpuente, M
    Falaschi, M
    Moreno, G
    Vidal, G
    [J]. FUNCTIONAL AND LOGIC PROGRAMMING, PROCEEDINGS, 1999, 1722 : 147 - 162
  • [50] Specialization of inductively sequential functional logic programs
    Alpuente, María
    Hanus, Michael
    Lucas, Salvador
    Vidal, Germán
    [J]. SIGPLAN Notices (ACM Special Interest Group on Programming Languages), 1999, 34 (09): : 273 - 282