Monographs in Theoretical Computer Science An EATCS Series Editors: W. Brauer G. Rozenberg A. Salomaa On behalf of the European Association for Theoretical Computer Science (EATCS) Advisory Board: G. Ausiello M. Broy C.S. Calude S. Even J. Hartmanis N. Jones T. Leighton M. Nivat C. Papadimitriou D. Scott Springer-Verlag Berlin Heidelberg GmbH J. C. M. Baeten C. A. Middelburg Process Algebra with Timing With 31 Figures ~Springer Authors Series Editors Prof. Dr. J. C. M. Baeten Prof. Dr. Wilfried Brauer Eindhoven University of Technology Institut rur Informatik, Division of Computer Science Technische Universitat Munchen P.O.Box 513 ArcisstraBe 21, 80333 Munchen, Germany 5600 MB Eindhoven, The Netherlands [email protected] [email protected] Prof. Dr. Grzegorz Rozenberg Prof. Dr. C. A. Middelburg Leiden Institute Eindhoven University of Technology of Advanced Computer Science Division of Computer Science University of Leiden P.O. Box 513 Niels Bohrweg 1,2333 CA Leiden, 5600 MB Eindhoven, The Netherlands The Netherlands [email protected] [email protected] and Utrecht University Praf. Dr. Arto Salomaa Department of Philosophy Turku Centre for Computer Science P.O. Box 80126 Lemminkaisenkatu 14A, 20520 Turku, Finland 3508 TC Utrecht, The Netherlands [email protected] Library of Congress Cataloging-in-Publication Data applied for Die Deutsche Bibliothek - CIP-Einheitsaufnahme Baeten, J. C. M.: Process algebra with timing / J. C. M. Baeten; C.A. Middelburg. ISBN 978-3-642-01788-3 ISBN 978-3-662-04995-2 (eBook) DOI 10.1007/978-3-662-04995-2 ACM Computing Classification (1998): D.1.3, D.2.1, D.2A, F.1.2, F.3.1-2 ISBN 978-3-642-07788-3 This work is subject to copyright. All rights are reserved, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, reuse of illus trations, recitation, broadcasting, reproduction on microfilm or in any other way, and storage in data banks. Duplication of this publication or parts thereof is permitted only under the provisions of the German Copyright Law of September 9, 1965, in its current version, and permission for use must always be obtained from Springer-Verlag Berlin Heidelberg GmbH. Violations are liable for prosecution under the German Copyright Law. © Springer-Verlag Berlin Heidelberg 2002 Originally published by Springer-Verlag Berlin Heidelberg New York in 2002 Softcover reprint of the hardcover 1s t edition 2002 The use of general descriptive names, trademarks, etc. in this publication does not imply, even in the absence of a specific statement, that such names are exempt from the relevant protective laws and therefore free for general use. Cover Design: KilnkelLopka Werbeagentur Typesetting: Camera ready by authors Printed on acid-free paper SPIN: 10865949 45/3142/XO· 543210 Preface This book is concerned with a number of theories that can be used for describ ing and analyzing systems of interacting components in case it is desirable or necessary to regard their time-dependent behavior. Society is becoming increasingly more dependent on complex computer based systems that are composed of several components that act concurrently and interact - to synchronize and communicate with each other. The com plexity of these systems arises to a great extent from the many ways in which their components can interact. The need that these components act and in teract on time as well adds considerably to the complexity. In developing such a system, it is important to be able to acquire a better understanding of the relevant issues at the conceptual level, to describe the system in a precise way at various levels of detail, and to analyze it on the basis of the descriptions. When the early algebraic theories about processes, such as ACP [16, 17, 20], CCS [49, 50] and CSP [27, 39], were developed for that purpose, the established opinion was still that timing is a concern that can more often than not be treated independently. It is therefore not surprising that timing is deliberately ignored in those theories. They have now all been extended to deal with timing. Timing may be needed for various reasons. Timing may simply be essential for the correct behavior of a system. This is, for example, the case with most controllers. Their correct behavior, often derived from physical laws, usually involves actions performed between certain time bounds. Even if timing is not essential for the correct behavior of a system, there may be good reasons to implement it in a way such that suitable timing becomes essential for the correct behavior. For example, for certain data communication protocols, whether they behave, at an appropriate level of abstraction, like a queue depends on the timing of certain actions. Still another reason may be that there is simply a need to pay much attention to performance aspects of a system. In this book, a coherent collection of four algebraic theories about pro cesses, each dealing with timing in a different way, is presented. The timing of actions is either relative (to the time at which the preceding action is performed) or absolute, and the time scale on which the time is measured VI Preface is either discrete or continuous. The presented theories are all extensions of ACP (Algebra of Communicating Processes). We use the term process to mean any system whose behavior is made up of discrete actions. Each action of a process is either performed synchronously with an action of another process, in which case an interaction takes place between those processes, or it is performed on its own. In the latter case, the action is often nothing but an interaction between subprocesses of the process concerned, i.e., an internal interaction. Our point of view is that not only the system of interest is a process, but also the components of which it is composed and the environment with which it interacts. Sending a message to another process and receiving a message from an other process are typical examples of the kinds of actions that are performed by a process. Synchronous communication of a message between two pro cesses is an example of an interaction that takes place when a send action of one process and a matching receive action of the other process are performed synchronously. Other examples of the kinds of actions that processes perform are: putting a message in a queue, fetching a message from a queue, reading a datum from a memory cell, and writing a datum to a memory cell. The theories about processes presented in this book are algebraic in the following ways: operators are used to compose processes and equations are used to define the nature of processes. Our intuitive understanding of the nature of the processes concerned provides the primary justification of the equations that are taken as axioms. However, we also present for each theory a mathematical model which is close to the intuitive understanding. Each theory makes fully precise, by introducing a collection of constants and operators, what terms can be used as mathematical expressions for the processes considered in the theory. These operators enable us to describe a system as a system composed of several components, and to describe the composition of the system and the environment with which it interacts. Each theory also makes fully precise, by introducing a collection of equations as ax ioms, how to establish whether two terms represent the same process. These equations enable us to analyze a described system by mere algebraic calcu lations. The presented model of the axioms is a suitable basis for checking properties that cannot be expressed in the form of an equation. The four theories about processes that deal with timing make up a co herent collection in the following sense. All four theories are generalizations of ACP without timing. The theory with absolute timing in which time is measured on a continuous time scale is a generalization of the theory with absolute timing in which time is measured on a discrete time scale. The two theories with absolute timing can easily be extended with a mechanism for parametric absolute timing which provides a way to deal with relative tim ing. That is, the extended theories are generalizations of the corresponding theories with relative timing. Preface VII If one theory is a generalization of another theory, this roughly means that the processes considered in the former theory essentially include the processes considered in the latter theory. That is the reason why abstraction from tim ing is possible in a theory with timing, and discretization is possible in the theory with absolute timing in which time is measured on a continuous time scale. Abstraction from timing yields processes considered in a theory with timing that correspond with processes considered in ACP without timing. Discretization yields processes considered in a theory in which time is mea sured on a continuous time scale that correspond with processes considered in a theory in which time is measured on a discrete time scale. Abstraction from timing enables analysis of systems without carrying the timing details where they are not needed. Discretization enables analysis of systems at a level where time is measured with a finite precision wherever that is sufficient. All four theories about processes that deal with timing are extended with a mechanism for abstraction from (internal) actions. This, together with ab straction from timing, enables us to verify whether two descriptions, one containing more implementation details than the other, represent the same system after appropriate abstraction. It seems appropriate to use the term process algebra to mean a model of an algebraic theory about processes. However, as customary, we mostly use the term process algebra to mean an algebraic theory about processes. Sometimes, we even use it to mean a collection of algebraic theories about processes - as in the title of this book. Outline of the Book This book is organized into three parts. Chapter 1 reviews ACP without timing, the core of the versions of ACP with timing presented in the four following chapters. Chapters 2-5 introduce different versions of ACP with timing. Chapters 6 and 7 introduce interesting extensions of these versions. Chapter 1, which is an introductory chapter, is primarily meant to enable the reader to acquire a good insight into the basic concepts of ACP-style process algebras in a setting without timing. In Chaps. 2-5, which build on Chap. 1, ACP is extended to capture timing in four different ways. Chapters 2 and 3 introduce versions of ACP with relative timing and absolute timing in which time is measured on a discrete time scale. The version introduced in Chap. 2 is considered to be the simplest version of ACP with timing. Chapters 4 and 5 introduce versions of ACP with relative timing and absolute timing in which time is measured on a continuous time scale. In each of the Chaps. 1-5, first the concepts around which the version concerned has been set up are explained informally and then a formal presen tation of the version is given. The formal presentation includes the signature (fixing the constants and operators that are considered) and the axioms of the theory concerned as well as transition rules from which a model for the theory VIII Preface can be obtained in a standard way. Examples are given of how true equations are derived from the axioms, and how possible transitions of processes (rep resenting their capabilities to perform actions or to idle) can be inferred from the transition rules. The use of each version is illustrated by means of some small examples concerning the description of simple processes found in prac tice. These small examples concern amongst other things a burglar alarm, a communication protocol known as the concurrent alternating bit protocol, a railroad crossing controller, and a gas burner controller. Larger examples including some algebraic calculations are also given. These larger examples concern a message-passing system, a communication protocol known as the positive acknowledgement with retransmission protocol, a mutual exclusion protocol known as Fischer's protocol, and a bottle filling system. Each of the Chaps. 2-5 concludes with a section that establishes connec tions between the theory introduced in that chapter and the ones introduced in the preceding chapters. These connections explain why the presented the ories are generalizations of certain others. In Chap. 6, the versions of ACP with timing introduced in Chaps. 2-5 are extended with abstraction from (internal) actions. In Chap. 7, the version of ACP with timing introduced in Chap. 5 is extended with three interesting features, viz. a feature that enables processes to interact with a state, a feature that enables processes to create processes, and a feature to enforce that certain actions take place as soon as possible. These features can be added in a similar way to the other versions of ACP with timing introduced in this book. There are also two appendices. Appendix A outlines the proofs of sound ness and completeness for the axioms of the version of ACP with timing introduced in Chap. 2. Appendix B introduces the basic definitions and re sults from equational logic and structural operational semantics on which the formal presentation of all theories and models included in this book are founded, and reviews some further relevant topics. The symbols used in the book are for the greater part listed in a glossary. How to Use the Book This book can be used for self-study by researchers in computer science or as supplementary reading in courses for graduate and advanced undergraduate students in computer science. Familiarity with first-order logic and elemen tary set theory is required. Some familiarity with universal algebra, equational logic and structural operational semantics would be helpful. The desirable background in these fields is briefly reviewed in Appendix B. Each chapter is a prerequisite for all subsequent chapters with the excep tion of the following: Chap. 3 is not a prerequisite for Chap. 4, and Chap. 6 is not a prerequisite for Chap. 7. The examples and exercises are integrated with the text. They should not be ignored. Preface IX Acknowledgements. This book brings together and streamlines a lot of work on process algebra with timing done since 1989 by a group of people in Amsterdam, Eindhoven and Utrecht under the guidance of Jan Bergstra. Most of that work was supported by European projects, notably CONCUR (ESPRIT), CONCUR2 (ESPRIT), CONFER (ESPRIT) and SPECS (RACE). Many people contributed in one way or another to this book: Jan Bergstra, Lou van den Dries, Wan Fokkink, Loe Feijs, Rob van Glabbeek, Jan Friso Groote, Steven Klusener, Michel Reniers, Gheorghe ~tefanescu, Jan Joris Vereijken, Chris Verhoef, Mark van der Zwaag and many others. We also want to thank the participants of the Training School on Techniques for Software Specification and Verification at UNU /liST (United Nations Univer sity, International Institute for Software Technology) in Macau, September 2001, and students attending the seminar on Process Algebra with Timing at Eindhoven University of Technology in the academic year 2000-2001, for pointing out errors and obscurities in drafts of the book. Eindhoven, June 2002 los Baeten and Kees Middelburg Contents Preface................................................... V 1. No Timing................................................ 1 1.1 Basic Process Algebra.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 1.1.1 Basic Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2 1.1.2 The Theories BPA and BPA.; . . . . . . . . . . . . . . . . . . . . . . 9 1.1.3 BPA with Recursion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 1.2 Algebra of Communicating Processes . . . . . . . . . . . . . . . . . . . . . 18 1.2.1 Additional Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19 1.2.2 The Theory ACP. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22 1.2.3 ACP with Recursion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 1.2.4 Some Calculations: Message-Passing System . . . . . . . . . 28 1.2.5 Postlude . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 2. Discrete Relative Timing . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 31 2.1 Basic Process Algebra. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 2.1.1 Basic Concepts.. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 2.1.2 The Theory BPA~t-ID. . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 2.1.3 BPA~t-ID with Recursion......................... 43 2.1.4 The Theory BPA~t . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 2.1.5 BPA~t with Recursion............................ 49 2.1.6 The Theory BPAdrt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 2.1.7 BPAdrt with Recursion............................ 53 2.2 Algebra of Communicating Processes . . . . . . . . . . . . . . . . . . . . . 53 2.2.1 Additional Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54 2.2.2 The Theory Acpdrt . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58 2.2.3 ACPdrt with Recursion. . . . . . . . . . . . . . . . . . . . . . . . . . . . 63 2.2.4 Some Calculations: PAR Protocol . . . . . . . . . . . . . . . . . . 64 2.2.5 Postlude . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 2.3 Connections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68 2.3.1 Relating ACPdrt to ACP . . . . . . . . . . . . . . . . . . . . . . . . . . 68 2.3.2 Relative Timing versus Absolute Timing . . . . . . . . . . . . 69