Program slicing is a well-known methodology that aims at identifying the program statements that (potentially) affect the values computed at some point of interest. Within imperative programming, this technique has been successfully applied to debugging, specialization, reuse, maintenance, etc. Due to its declarative nature, adapting the slicing notions and techniques to a logic programming setting is not an easy task. In this work, we define the first, semantics-preserving, forward slicing technique for logic programs. Our approach relies on the application of a conjunctive partial deduction algorithm for a precise propagation of information between calls. We do not distinguish between static and dynamic slicing since partial deduction can naturally deal with both static and dynamic data. A slicing tool has been implemented in ECCE, where a post-processing transformation to remove redundant arguments has been added. Experiments conducted on a wide variety of programs are encouraging and demonstrate the usefulness of our approach, both as a classical slicing method and as a technique for code size reduction. © Springer-Verlag Berlin Heidelberg 2005.
CITATION STYLE
Leuschel, M., & Vidal, G. (2005). Forward slicing by conjunctive partial deduction and argument filtering. In Lecture Notes in Computer Science (Vol. 3444, pp. 61–76). Springer Verlag. https://doi.org/10.1007/978-3-540-31987-0_6
Mendeley helps you to discover research relevant for your work.