Back to Search Start Over

Declarative debugging of rewriting logic specifications

Authors :
Riesco Rodríguez, Adrián
Verdejo López, José Alberto
Martí Oliet, Narciso
Caballero, Rafael
Source :
E-Prints Complutense: Archivo Institucional de la UCM, Universidad Complutense de Madrid, E-Prints Complutense. Archivo Institucional de la UCM, instname
Publication Year :
2010
Publisher :
Departamento de Sistemas Informáticos y Computación, Universidad Complutense de Madrid, 2010.

Abstract

Declarative debugging is a semi-automatic technique that starts from an incorrect computation and locates a program fragment responsible for the error by building a tree representing this computation and guiding the user through it to find the error. Membership equational logic (MEL) is an equational logic that in addition to equations allows to state membership axioms characterizing the elements of a sort. Rewriting logic is a logic of change that extends MEL by adding rewrite rules, that correspond to transitions between states and can be nondeterministic. We propose here a calculus to infer reductions, sort inferences, normal forms and least sorts with the equational part, and rewrites and sets of reachable terms through rules. We use an abbreviation of the proof trees computed with this calculus to build appropriate debugging trees for both wrong (an incorrect result obtained from an initial result) and missing answers (results that are erroneous because they are incomplete), whose adequacy for debugging is proved. Using these trees we have implemented a declarative debugger for Maude, a high-performance system based on rewriting logic, whose use is illustrated with an example.

Details

Database :
OpenAIRE
Journal :
E-Prints Complutense: Archivo Institucional de la UCM, Universidad Complutense de Madrid, E-Prints Complutense. Archivo Institucional de la UCM, instname
Accession number :
edsair.dedup.wf.001..5b0a79303f7a7fbdcb8057ba99d3b991