© University of Kent - Contact | Feedback | Legal | FOI | Cookies
Specifying and Refining Internal Operations in Z
John Derrick, Eerke Boiten, Howard Bowman, and Maarten Steen
Formal Aspects of Computing, 10:182-196, December 1998.Abstract
Abstract
An important aspect in the specification of distributed systems is the role of the internal (or unobservable) operation. Such operations are not part of the interface to the environment (i.e. the user cannot invoke them), however, they are essential to our understanding and correct modelling of the system. In this paper we are interested in the use of the formal specification notation Z for the description of distributed systems. Various conventions have been employed to model internal operations when specifying such systems in Z. If internal operations are distinguished in the specification notation, then refinement needs to deal with internal operations in appropriate ways.
Using an example of a telecommunications protocol we show that standard Z refinement is inappropriate for refining a system when internal operations are specified explicitly. We present a generalization of Z refinement, called weak refinement, which treats internal operations differently from observable operations when refining a system. We discuss the role of internal operations in a Z specification, and in particular whether an equivalent specification not containing internal operations can be found. The nature of divergence through livelock is also discussed.
Keywords: Z; Refinement; Distributed Systems; Internal Operations; Process Algebras; Concurrency.
Download publication 439 kbytes (PostScript)
Bibtex Record
@article{648, author = {John Derrick and Eerke Boiten and Howard Bowman and Maarten Steen}, title = {Specifying and {R}efining {I}nternal {O}perations in {Z}}, month = {December}, year = {1998}, pages = {182-196}, keywords = {determinacy analysis, Craig interpolants}, note = {}, doi = {}, url = {http://www.cs.kent.ac.uk/pubs/1998/648}, journal = {Formal Aspects of Computing}, publisher = {Springer}, volume = {10}, }