Maude: specification and programming in rewriting logic

  • Authors:
  • M. Clavel;F. Durán;S. Eker;P. Lincoln;N. Martí-Oliet;J. Meseguer;J. F. Quesada

  • Affiliations:
  • Departamento de Filosofía, Universidad de Navarra, Spain;ETSI Informática, Universidad de Málaga, Spain;Computer Science Lab, SRI International, 333 Ravenswood Ave., Menlo Park, CA;Computer Science Lab, SRI International, 333 Ravenswood Ave., Menlo Park, CA;Facultad de Matemáticas, Universidad Complutense, Madrid, Spain;Computer Science Lab, SRI International, 333 Ravenswood Ave., Menlo Park, CA;Centro de Informática Científica de Andalucía, Sevilla, Spain

  • Venue:
  • Theoretical Computer Science - Rewriting logic and its applications
  • Year:
  • 2002

Quantified Score

Hi-index 0.01

Visualization

Abstract

Maude is a high-level language and a high-performance system supporting executable specification and declarative programming in rewriting logic. Since rewriting logic contains equational logic, Maude also supports equational specification and programming in its sublanguage of functional modules and theories. The underlying equational logic chosen for Maude is membership equational logic, that has sorts, subsorts, operator overloading, and partiality definable by membership and equality conditions. Rewriting logic is reflective, in the sense of being able to express its own metalevel at the object level. Reflection is systematically exploited in Maude endowing the language with powerful metaprogramming capabilities, including both user-definable module operations and declarative strategies to guide the deduction process. This paper explains and illustrates with examples the main concepts of Maude's language design, including its underlying logic, functional, system and object-oriented modules, as well as parameterized modules, theories, and views. We also explain how Maude supports reflection, metaprogramming and internal strategies. The paper outlines the principles underlying the Maude system implementation, including its semicompilation techniques. We conclude with some remarks about applications, work on a formal environment for Maude, and a mobile language extension of Maude.