Abstract
The traditional notion of superposition has been used for supporting two distinct aspects of parallel program design: composition and refinement. This is because, when trace-based semantics of concurrency are considered, which is typical of most formal methods, these two relationships are modelled as inclusion between sets of behaviours. However, when forms of non-deterministic behaviour have to be considered, which is the case for component and service-based development, these two aspects do not coincide. In this paper, we show how the two roles of superposition can be separated and supported at the language and semantic levels. For this purpose, we use a categorical formalisation of program design in the language CommUnity that we are also using for addressing architectural concerns, another area in which the distinction between composition and refinement is particularly important.
Original language | English |
---|---|
Pages (from-to) | 5-18 |
Number of pages | 14 |
Journal | Formal Aspects of Computing |
Volume | 16 |
Issue number | 1 |
DOIs | |
Publication status | Published - 1 Apr 2004 |
Keywords
- Composition
- Refinement
- Superposition
ASJC Scopus subject areas
- Software
- Theoretical Computer Science