Avoiding diamonds in desynchronisation

  • Beohar H
  • Cuijpers P
  • 3


    Mendeley users who have this article in their library.
  • 1


    Citations of this article.


The design of concurrent systems often assumes synchronous communication between different parts of a system. When system components are physically apart, this assumption becomes inappropriate. Desynchronisation is a technique that aims to implement a synchronous design in an asynchronous manner by placing buffers between the components of the synchronous design. When queues are used as buffers, the so-called 'diamond property' (among others) ensures correct operation of the desynchronised design. However, this property is difficult to establish in practice. In this paper, we give sufficient and necessary conditions under which a concrete synchronous design (i.e., without the unobservable action) is equivalent to an asynchronous design and formally prove that the diamond property is no longer needed for desynchronisation when half-duplex queues are used as a communication buffer. Furthermore, we discuss how the half-duplex condition can be further relaxed when the diamond property can be partially guaranteed. To illustrate how this theory may be applied, we desynchronise the synchronous systems that are synthesised using supervisory control theory. © 2013 Elsevier B.V.

Author-supplied keywords

  • Branching bisimulation
  • Desynchronisation
  • Equivalence checking of infinite state systems
  • Synchrony to asynchrony

Get free article suggestions today

Mendeley saves you time finding and organizing research

Sign up here
Already have an account ?Sign in

Find this document


  • H. Beohar

  • P. J.L. Cuijpers

Cite this document

Choose a citation style from the tabs below

Save time finding and organizing research with Mendeley

Sign up for free