A theoretical basis for stepwise refinement and the programming calculus (Q578892): Difference between revisions

From MaRDI portal
Importer (talk | contribs)
Changed an Item
Set OpenAlex properties.
 
(2 intermediate revisions by 2 users not shown)
Property / MaRDI profile type
 
Property / MaRDI profile type: MaRDI publication profile / rank
 
Normal rank
Property / full work available at URL
 
Property / full work available at URL: https://doi.org/10.1016/0167-6423(87)90011-6 / rank
 
Normal rank
Property / OpenAlex ID
 
Property / OpenAlex ID: W2087713039 / rank
 
Normal rank
links / mardi / namelinks / mardi / name
 

Latest revision as of 21:03, 19 March 2024

scientific article
Language Label Description Also known as
English
A theoretical basis for stepwise refinement and the programming calculus
scientific article

    Statements

    A theoretical basis for stepwise refinement and the programming calculus (English)
    0 references
    0 references
    1987
    0 references
    A uniform treatment of specifications, programs, and programming is presented. The treatment is based on adding a specification statement to a given procedural language and defining its semantics. The extended language is thus a specification language and programs are viewed as a subclass of specifications. A partial ordering on specifications/programs corresponding to 'more defined' is defined. In this partial ordering the program/specification hybrids that arise in the construction of a program by stepwise refinement form a monotonic sequence. We show how Dijkstra's calculus for the derivation of programs corresponds to constructing this monotonic sequence. Formalizing the calculus thus gives some insight into the intellectual activity it demands and allows us to hint at further developments.
    0 references
    specifications
    0 references
    programming
    0 references
    semantics
    0 references
    partial ordering
    0 references
    stepwise refinement
    0 references
    Dijkstra's calculus
    0 references

    Identifiers