Theories
The semantic foundation of the UTP is the first-order predicate calculus, augmented with fixed point constructs from second-order logic. Following the tradition of Eric Hehner, programs are predicates in the UTP, and there is no distinction between programs and specifications at the semantic level. In the words of Hoare:
A computer program is identified with the strongest predicate describing every relevant observation that can be made of the behaviour of a computer executing that program.
In UTP parlance, a theory is a model of a particular programming paradigm. A UTP theory is composed of three ingredients:
- an alphabet, which is a set of variable names denoting the attributes of the paradigm that can be observed by an external entity;
- a signature, which is the set of programming language constructs intrinsic to the paradigm; and
- a collection of healthiness conditions, which define the space of programs that fit within the paradigm. These healthiness conditions are typically expressed as monotonic idempotent predicate transformers.
Program refinement is an important concept in the UTP. A program is refined by if and only if every observation that can be made of is also an observation of . The definition of refinement is common across UTP theories:
where denotes the universal closure of all variables in the alphabet.
Read more about this topic: Unifying Theories Of Programming
Famous quotes containing the word theories:
“The wise man regulates his conduct by the theories both of religion and science. But he regards these theories not as statements of ultimate fact but as art-forms.”
—J.B.S. (John Burdon Sanderson)
“A work of art that contains theories is like an object on which the price tag has been left.”
—Marcel Proust (18711922)