Modularity and Implementation of Operational Semantics
Abstract
Structural operational semantics is a popular technique for specifying the meaning of programs by means of inductive clauses. One seeks syntactic restrictions on those clauses so that the resulting operational semantics is well-behaved. This approach is simple and concrete but it has some drawbacks. Turi pioneered a more abstract categorical treatment based upon the idea that operational semantics is essentially a distribution of syntax over behaviour. In this article we take Turi’s approach in two new directions. Firstly, we show how to write operational semantics as modular components and how to combine such components to specify complete languages. Secondly, we show how the categorical nature of Turi’s operational semantics makes it ideal for implementation in a functional programming language such as Haskell.
BibTeX
@article{Jaskel-msfp08,
title = "Modularity and Implementation of Mathematical Operational Semantics",
journal = "Electronic Notes in Theoretical Computer Science",
volume = "229",
number = "5",
pages = "75 - 95",
year = "2011",
note = "Proceedings of the Second Workshop on Mathematically Structured Functional Programming (MSFP 2008)",
issn = "1571-0661",
doi = "DOI: 10.1016/j.entcs.2011.02.017",
url = "http://www.sciencedirect.com/science/article/B75H1-528Y84D-5/2/7158acc949c31d257f1429359a257c69",
author = "Mauro Jaskelioff and Neil Ghani and Graham Hutton",
keywords = "Modularity",
keywords = "Category Theory",
keywords = "Operational Semantics",
keywords = "Haskell"
}