University of Oxford Logo University of OxfordDepartment of Computer Science - Home

Experience Report: A Haskell interpreter for CellML

Jonathan Cooper and Steve McKeever

Abstract

In this paper we present our use of functional programming (FP), specifically Haskell, to provide an operational semantics for a domain-specific language, CellML, that describes mathematical models of biological processes. We analyse the benefits and shortcomings of this approach, in comparison with other semantic definitions for CellML. It is our claim that using FP for our semantics results in a more concise and useful artifact for describing what such a model means. The use of lazy evaluation removes the need to explicitly determine an evaluation order for the model, resulting in a more elegant interpreter. Crucially, using FP enables us to prove the correctness of optimisation techniques for such models. This gives us more confidence in scientific deductions from simulation results. We compare the Python implementation of these optimisation techniques with our use of Haskell in proving their correctness.

Details

Address

New York‚ NY‚ USA

ISBN

978−1−59593−815−2

Journal

ICFP '07: Proceedings of the 2007 ACM SIGPLAN international conference on Functional programming

Location

Freiburg‚ Germany

Month

October

Pages

247–250

Publisher

ACM Press

Year

2007

Links

BibTeX

DOI (10.1145/1291151.1291190)

ISBN (978-1-59593-815-2)

Related pages

People