|COOKIES: By using this website you agree that we can place Google Analytics Cookies on your device for performance monitoring.|
Abstract separation algebra
If you have a question about this talk, please contact Sam Staton.
I show how both Hoare triples and Plotkin triples can be replaced by an abstract algebra, in which all the primitives are pairs and singletons, i.e., constants, binary operators and binary predicates. The algebra deals separately but equally simply with both sequential and concurrent composition of programs; and many further program primitives and structuring operators like choice and disjoint concurrency can be introduced individually, one at a time. The relevant proof rules for Hoare Triples, and the relevant Plotkin triples for operational semantics, are derived simply and separately for each binary operator.
Familiar algebraic properties – associativity, commutivity, monotonicity, idempotence are widely reused. The interactions between operators can be described just two at a time by distributivity laws. These include mutual distribution, a weak form of the exchange law of two-category theory. This leads to an elementary presentation of separation logic and of Kleene algebra.
Thus we extend to the mathematics of programming the old saying about marriage: ‘two’s fun, three’s none’. Down with the triple!
This talk is part of the Semantics Lunch (Computer Laboratory) series.
This talk is included in these lists:
Note that ex-directory lists are not shown.
Other listsComputer Laboratory talks Gates Cambridge Annual Lecture Statistical Methods for Cognitive Psychologists
Other talksStem Cell and Higher-Order Chromatin Structure Should we screen for diabetes and related cardiovascular risk? Moving Forward with Stem Cell Therapy Studies on Enzymatic Catalysis of Polar Reactions: Proton Transfer, Hydride Transfer and Decarboxylation From Graphon to Graphex: Models and Estimators for Sparse Networks using Exchangeable Random Measures Structure, Biology and Therapeutic Potential of Novel ER Located Growth Factors