Branching pomsets: Design, expressiveness and applications to choreographies
Journal of Logical and Algebraic Methods in Programming , Volume 136 p. 100919:1- 100919:36
Choreographic languages describe possible sequences of interactions among a set of agents. Typical models are based on languages or automata over sending and receiving actions. Pomsets provide a more compact alternative by using a partial order to explicitly represent causality and concurrency between these actions. However, pomsets offer no representation of choices, thus a set of pomsets is required to represent branching behaviour. For example, if an agent Alice can send one of two possible messages to Bob three times, one would need a set of 2×2×2 distinct pomsets to represent all possible branches of Alice's behaviour. This paper proposes an extension of pomsets, named branching pomsets, with a branching structure that can represent Alice's behaviour using 2+2+2 ordered actions. We compare the expressiveness of branching pomsets with that of several forms of event structures from the literature. We encode choreographies as branching pomsets and show that the pomset semantics of the encoded choreographies are bisimilar to their operational semantics. Furthermore, we define well-formedness conditions on branching pomsets, inspired by multiparty session types, and we prove that the well-formedness of a branching pomset is a sufficient condition for the realisability of the represented communication protocol. Finally, we present a prototype tool that implements our theory of branching pomsets, focusing on its applications to choreographies.
|, , ,|
|Journal of Logical and Algebraic Methods in Programming|
|Organisation||Centrum Wiskunde & Informatica, Amsterdam (CWI), The Netherlands|
Edixhoven, L.J, Jongmans, S.-S.T.Q, Proença, J.M.P, & Castellani, I. (2024). Branching pomsets: Design, expressiveness and applications to choreographies. Journal of Logical and Algebraic Methods in Programming, 136, 100919:1–100919:36. doi:10.1016/j.jlamp.2023.100919