School of Computing

How to produce correct software - an introduction to formal specification and program development by transformations

E.A. Boiten, H.A. Partsch, D. Tuijnman, and N. V"olker

Computer Journal, 35(6):182-196, December 1992.

Abstract

The task of software production is to build software systems which are to fulfil certain requirements. For years the approach has been to build up by trial and error a program which, having satisfied carefully prepared test data, offers a plausible solution to the problem. But is it correct? Even for toy examples this is not obvious. In particular, it is often not even clear whether the original problem has been fully understood. The reason for this dilemma is that the transition from the informal problem statement to the final program is too big to be intellectually managable. To master these problems, we advocate a software development method where the whole process is split into smaller steps by introducing formal specifications for (parts of) the problem and then stepwisely deriving efficient programs by correctness-preserving transformations.



Bibtex Record

@article{166,
author = {E.A. Boiten and H.A. Partsch and D. Tuijnman and             N. V{"o}lker},
title = {How to produce correct software -- an introduction to             formal specification and program development             by transformations},
month = {December},
year = {1992},
pages = {182-196},
keywords = {determinacy analysis, Craig interpolants},
note = {},
doi = {},
url = {http://www.cs.kent.ac.uk/pubs/1992/166},
    journal = {Computer Journal},
    number = {6},
    volume = {35},
}

School of Computing, University of Kent, Canterbury, Kent, CT2 7NF

Enquiries: +44 (0)1227 824180 or contact us.

Last Updated: 21/03/2014