Deriving Barbed Bisimulations for Bigraphical Reactive Systems Electronic Communications of the EASST Volume 16 (2009) Proceedings of the Doctoral Symposium at the International Conference on Graph Transformation (ICGT 2008) Deriving Barbed Bisimulations for Bigraphical Reactive Systems Davide Grohmann, Marino Miculan 15 pages Guest Editors: Andrea Corradini, Emilio Tuosto Managing Editors: Tiziana Margaria, Julia Padberg, Gabriele Taentzer ECEASST Home Page: http://www.easst.org/eceasst/ ISSN 1863-2122 http://www.easst.org/eceasst/ ECEASST Deriving Barbed Bisimulations for Bigraphical Reactive Systems Davide Grohmann1, Marino Miculan2 1 grohmann@dimi.uniud.it, 2 miculan@dimi.uniud.it Department of Mathematics and Computer Science, University of Udine, Italy Abstract: We study the definition of a general abstract notion of barbed bisimilarity for reactive systems on bigraphs. More precisely, given a bigraphical reactive sys- tem, we define the corresponding barbs from the contextual labels given by the IPO construction, in a general and systematic way. These barbs correspond to observe which names on the interface are actually involved in reactions (and how). As examples, we apply this construction to the (bigraphical representation of the) π -calculus and of Mobile Ambients, and compare the resulting barbed equivalences with those previously known for these calculi. Keywords: Bigraphs, barbed bisimulations, π -calculus, mobile ambients. 1 Introduction Bigraphical Reactive Systems (BRSs) [12] have been proposed as a promising meta-model for concurrent, communicating, mobile systems. They have been successfully used for representing many calculi and models, e.g. CCS, π -calculus, Petri Nets, Mobile Ambients, Fusion calculus among others [8, 11, 2, 5]. BRSs owe much of their expressivity to the fact that their states are bigraphs, semi-structured data which can represent at once both the (physical, logical) location and the connections of the components of a system. The dynamics of the system is represented by a set of rewrite rules on this semi-structured data. An important property of BRSs is that they support the systematic definition of labelled tran- sition systems via so-called IPO construction [8], which identifies the labels for a given agent as the minimal contexts which trigger a transition. Notably, the strong bisimilarity induced by this LTS is always a congruence, and this has been extended also to weak bisimilarity [6]. In this paper, we continue this line of research by defining a general abstract notion of barbed bisimilarity for BRSs. Barbed bisimilarity is interesting for many reasons; e.g., its definition does not rely on a LTS, and usually barbed bisimilarity is coarser than strong bisimilarity. Intuitively, barbed bisimilarity compares agents by looking only at the channels, or barbs, which they expose to the surrounding environment. This turns out to be sufficiently expressive, for calculi whose reactions are essentially triggered by names. However, there is no general and systematic way for identify which names of an agent have to be observed, and which is their role; instead, barbs are usually defined by means of some ad hoc intensional definition on the syntax of the calculus; e.g., in the π -calculus, barbs are the subjects of “active” prefixes; in Mobile Ambients, they are the names of top-level ambients. To overcome this problem, in this paper we propose a general, systematic approach to define barbs for a bigraphic reactive system. We aim to formalize the intuitive idea that “barbs are the 1 / 15 Volume 16 (2009) mailto:grohmann@dimi.uniud.it mailto:miculan@dimi.uniud.it Deriving Barbed Bisimulations for Bigraphical Reactive Systems We have implemented the resulting algorithm in our BPL Tool, which we briefly describe in Section 6. We also present an example of a bigraphical reactive system, an encoding of the polyadic ! calculus, and show how it can be used to simulate a simple model of a mobile phone system. Bigraphical reactive systems are related to general graph transformation systems; Ehrig et al. [10] provide a recent comprehensive overview of graph transformation systems. In particular, bigraph matching is related to the general graph pattern matching (GPM) problem, so general GPM algorithms might also be applicable to bigraphs [11, 14, 20, 21]. As an alternative to implementing matching for bigraphs, one could try to formalize bigraphical reactive systems as graph transformation systems and then use an existing implementation of graph transformation systems. Some promising steps in this direction have been taken [19], but they have so far fallen short of capturing precisely all the aspects of binding bigraphs. For a more detailed account of related work, in particular on relations between BRSs, graph transformations, term rewriting and term graph rewriting, see the Thesis of Damgaard [8, Section 6]. The remainder of this paper is organized as follows. In Section 2 we give an informal presentation of bigraphical reactive systems and in Section 3 we present our matching algorithm: we first recall the graph-based inductive char- acterization, then we develop a term-based inductive characterization, which forms the basis for our implementation of matching. In Section 4 we describe how our implementation deals with the remaining nondeterminism and in Sec- tion 5 we discuss a couple of auxiliary technologies needed for the implementation of the term-based matching rules. In Section 6 we finally describe the BPL Tool and present an example use of it. We conclude and discuss future work in Section 7. 2. Bigraphs and Reactive Systems In the following, we present bigraphs informally; for a formal definition, see the work by Jensen and Milner [13] and Damgaard and Birkedal [9]. 2.1. Concrete Bigraphs A concrete binding bigraph G consists of a place graph GP and a link graph GL. The place graph is an ordered list of trees indicating location, with roots r0, . . . , rn, nodes v0, . . . , vk, and a number of special leaves s0, . . . , sm called sites, while the link graph is a general graph over the node set v0, . . . , vk extended with inner names x0, . . . , xl , and equipped with hyper edges, indicating connectivity. We usually illustrate the place graph by nesting nodes, as shown in the upper part of Figure 1 (ignore for now the interfaces denoted by “ : · !· ”). A link is a hyper edge of the link graph, either an internal edge e or a name y. Links Bigraph G : "3, [{},{},{x0, x2}], X# ! "2, [{y0},{}],Y # 0 1 2 y0 y1 y2 x0 x2 x1 e2 v0 v1 v2 v3 e1 X ={x0, x1, x2} Y ={y0, y1, y2} Place graph GP : 3 ! 2 roots: sites: r0 v0 v1 s0 v2 r1 v3 s2 s1 Link graph GL : X ! Y names: inner names: y0 y1 y2 v0 v1 v2 v3 x0 x2 x1 e1 e2 Fig. 1. Example bigraph illustrated by nesting and as place and link graph. 2 Figure 1: A binding bigraph (picture taken from [1]). names of an agent, which are involved in reactions”, by using the contextual labels given by the IPO construction: for each agent, we examine only its IPO labels for finding out the names which are effectively used in reactions. This leads to two notions of barb, IPO barb and decorated IPO barb, which differ on the information about names we extract from IPO labels: in the decorated version, we take advantage of the link and place graphs of the IPO labels to observe also the “role” that each name has in reactions. Notice that we use the IPO labels only for definining barbs, and not the bisimilarity itself which instead relies on the reaction relation only. In Section 2, after having recalled the basic definitions about binding bigraphs, we introduce the two barbed bisimilarities for binding bigraphs (Definitions 8 and 9). Then, in Sections 3 and 4 we apply this theory to the π -calculus and Mobile Ambients, respectively. For each calculus, we give its encoding as BRS, calculate the IPO labels, and compare the resulting IPO barbed bisimilarity with the standard barbed bisimilarities of these calculi. It turns out that in the case of π -calculus, IPO barbed bisimilarity is finer than standard barbed bisimilarity, but IPO barbed congruence and standard barbed congruence coincide (Proposition 5). On the other hand, in the case of Mobile Ambients, IPO barbed bisimilarities and congruence are finer than their standard counterparts; the reason is that IPO labels allow to observe names also used in capabilities, and not only names of top-level ambients. 2 Barbed bisimilarities for Binding Bigraphs 2.1 Binding Bigraphs In this section we recall Milner’s binding bigraphs1. Intuitively, a binding bigraph represents an open system, so it has an inner and an outer interface to “interact” with subsystems and the surrounding environment, see Figure 1. The widths of the interfaces describe the roots in the 1 Binding bigraphs generalize pure bigraphs for dealing with calculi with binders such as π -calculus. The results presented in this papers hold also in the particular case of pure bigraphs, which suffice for e.g. Mobile Ambients. Proc. Doctoral Symposium ICGT 2008 2 / 15 ECEASST outer interface (that is, the various locations where the nodes live) and the sites in the inner interface (that is, the holes where other bigraphs can be inserted). On the other hand, the names in the interfaces describes the free links, that is end points where links from the outside world can be pasted, creating new links among nodes. We refer the reader to [8, 9] for more details. Let K be a binding signature of controls, and ar : K → N×N be the arity function. The arity pair (h, k) (written h → k) consists of the binding arity h and the free arity k, indexing respectively the binding and the free ports of a control. Definition 1 A binding interface is 〈m, loc, X〉, where m is a finite ordinal (called width), X is a finite set of names, and loc : X → m]{⊥} is a locality map associating some of the names X with a site in m. If loc(x) = s then x is located at s, or local to s; if loc(x) = ⊥ then x is global. We shall some times represent the locality map as a vector ~X = (X0, . . . , Xm−1) of disjoint subsets, where Xs is the set of names local to s; thus X \~X are the global names. We call an interface local (resp. global) if all its names are local (resp. global). Definition 2 A binding bigraph G : 〈m, loc, X〉→ 〈n, loc′,Y〉 is defined as a (pure) bigraph Gu : 〈m, X〉→〈n,Y〉 satisfying certain locality conditions (see below). Gu is defined by composing a place graph GP, describing the nesting of nodes, and a link graph GL, describing the (hyper-)links among nodes. Gu = (V, E, ctrl, GP, GL) : 〈m, X〉→〈n,Y〉 (pure bigraph) GP = (V, ctrl, prnt) : m → n (place graph) GL = (V, E, ctrl, link) : X →Y (link graph) where V, E are the sets of nodes and edges respectively, ctrl : V → K is the control map, which assigns a control to each node, prnt : m]V → V ]n is the (acyclic) parent map, P = ∑v∈V π1(ar(ctrl(v))) is the set of ports and B = ∑v∈V π2(ar(ctrl(v))) is the set of bindings (as- sociated to all nodes), and link : X ]P → E ]B]Y is the link map. The locality conditions are the following: 1. if a link is bound, then its inner names and ports must lie within the node that binds it; 2. if a link is free, with outer name x, then x must be located in every region that contains any inner name or port of the link. Definition 3 The category of binding bigraphs over a signature K (BBG(K )) has local inter- faces as objects, and binding bigraphs as morphisms. Given two local bigraphs G : 〈m, loc, X〉→〈n, loc′,Y〉, H : 〈n, loc′,Y〉→〈k, loc′′, Z〉, the com- position H ◦G : 〈m, loc, X〉→〈k, loc′′, Z〉 is defined by composing their place and link graphs: 1. the composition of GP : m → n and H P : n → k is define as H P ◦GP = (VG ]VH , ctrlG ]ctrlH , (idVG ] prntH )◦(prntG ]idVH )) : n → k; 2. the composition of GL : X →Y and H L : Y → Z is defined as H L ◦GL = (VG ]VH , EG ]EH , ctrlG ]ctrlH , (idEG ]linkH )◦(linkG ]idPH )) : X → Z. 3 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems An important operation about (bi)graphs, is the tensor product. Intuitively, the tensor product of G : 〈m, loc, X〉→〈n, loc′′,Y〉 and H : 〈m′, loc′, X′〉→〈n′, loc′′′,Y ′〉, is a bigraph G⊗H : 〈m + m′, loc] loc′, X ]X′〉→〈n + n′, loc′′] loc′′′,Y ]Y ′〉 is defined when X ∩X′ = Y ∩Y ′ = /0 and it obtained by putting “side by side” G and H, without merging any root nor any name in the interfaces. It is easy to check that composition and tensor preserve the locality conditions. Two useful variant of tensor product can be defined using tensor and composition: the parallel product ‖, which merges shared global names between two bigraphs, and the prime product |, that moreover merges all roots in a single one. Due to lack of space, we refer the reader to [9]. 2.2 Bigraphical reactive systems Bigraphical reactive systems (BRSs) are reactive systems in the sense of [10], built over binding bigraphs [8]. A BRS consists of a set of bigraphical rewrite rules, together with a definition of the contexts (i.e., bigraphs with holes), called active context, where rules redexes can be found in order to be rewritten. Definition 4 Controls of a signature are either active, passive or atomic. Atomic controls can- not contain any node (and hence must be a leaf of the place and its binding arity is zero). A loca- tion (i.e., an element in the domain of prnt) is active if all its ancestors have active controls (the roots are active); otherwise it is passive. A context is active if all its holes are active locations. It is easy to check that active contexts form a compositional reflective sub-category of bi- graphs, which we denote by A , the category of active contexts. Definition 5 A bigraphical reactive system (BRS) D(K , R) is formed by BBG(K ) equipped with the subcategory A of active contexts, and a set R of (parametric) reaction rules, that is pairs l, r : 〈m, loc, X〉→〈n, loc′,Y〉 (usually written as l _ r). The reaction relation _ is the relation between ground bigraphs given by the following rule: for some A ∈ A , l _ r ∈ R, d ground : g = A◦l ◦d and h = A◦r◦d g _ h 2.3 Minimal labels for BRSs In order to derive systematically labelled transition systems (LTSs) from reactive systems, Leifer and Milner in [10] proposed to consider as labels the “minimal” contexts which can trigger a reaction. Such minimality can be elegantly defined as a categorial universal property, i.e., introducing the relative pushouts (RPOs) and idem pushouts (IPOs). Definition 6 Given a span ( f0, f1) and an its bound (g0, g1) as shown in Figure 2(1) 1. a candidate RPO is a triple (h0, h1, h) such that the diagram in Figure 2(1) commutes. 2. an RPO (h0, h1, h) is a candidate RPO such that given any other candidate RPO (k0, k1, k) there exists a unique mediating arrow j such that the diagram in Figure 2(2) commutes. 3. an IPO is an RPO having as the third component an identity (as in Figure 2(3)). Proc. Doctoral Symposium ICGT 2008 4 / 15 ECEASST f1f0 h1h0 g1g0 h f1f0 h1h0 g1g0 h j k1 k0 k f1f0 h1h0 g1g0 id (1) (2) (3) Figure 2: A candidate RPO (1), an RPO (2) and an IPO (3). Proposition 1 The category BBG has RPOs, and hence IPOs2. Following [10], the labels of an agent are the IPOs with respect to any reaction rule: Definition 7 (IPO labels) Let D(K , R) be a BRS, and a : ε →〈m, loc, X〉 an agent. An IPO label for a (in D ) is a bigraph ` such that there exists a rule l _ r ∈ R, a parameter d and an active context D such that (`, D, id) is an IPO for (a, l ◦d). We will denote by IPO(a) the set of all IPO labels for a. 2.4 Defining barbs from IPO labels In this section we give a way to define systematically barbs over bigraphs using the IPO labels. In general, a bigraphic barb is a predicate over ground bigraphs, observing some names on the interface. More precisely for a bigraph a : ε →〈m, loc, X〉, a bigraphic barb is a (possibly empty) subset X′ ⊆ X of the outer names of a; we denote it as a ↓ X′. The first family of barbs we define are IPO barbs. Intuitively, a name of an agent is in the IPO barb if there exists an IPO label that interacts (non trivially) with the agent on such a name. Definition 8 (IPO barbs) Let D(K , R) be a BRS, and a : ε →〈m, loc, X〉 a ground bigraph. For each ` ∈ IPO(a), the corresponding IPO barb (for a) is the set X′ ⊆ X defined as X′ = {x ∈ X | link`(x) = link`(p) for some p ∈ P̀ ](X \{x})}. We write a ↓I X′ for X′ is a IPO barb for a. In some cases we need to understand how each name is used by the agent. Intuitively, the role of a name can be figured out by looking at the control it is connected to, in the IPO label; e.g., in the case of π -calculus (Section 3), a name acts as an input channel when is connected to a “send” control in the IPO label. We can get this information by looking at the link graph of the label. In general, however, for a reaction to take place not only the names must be connected to the right controls, but these must be in the correct position within the IPO label. Thus, we can say that the role played by the name is given by the control it is connected to, and its position in the label; the latter can be obtained from the place graph of the label. Formally: Definition 9 (decorated IPO barb) Let D(K , R) be a BRS, and a : ε →〈m, loc, X〉 a ground bigraph. For each ` ∈ IPO(a), the corresponding decorated IPO barb (for a) is a set of pairs X′ = {(x′0, T0), . . . , (x′n−1, Tn−1)} such that {x′0, . . . , x′n−1} is the IPO barb for a corresponding to `, and for i = 0, . . . , n−1, Ti is the set satisfying the following properties: 2 More precisely, RPOs are constructed in the s-category ′BBG and then mapped down into the category BBG. 5 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems 1. 〈int〉∈ Ti iff there exists x ∈ X \{x′i} such that link`(x) = link`(x′i) and loc(x) = ⊥; 2. 〈ctrl(wn), . . . , ctrl(w1), int〉∈ Ti iff there exists x ∈ X \{x′i} such that link`(x) = link`(x′i) and loc`(x) = j, and there exist w1, . . . , wn ∈ V` and a root k such that prnt`( j) = w1, prnt`(wz) = wz+1 (z = 1, . . . , n−1), prnt`(wn) = k. 3. 〈ctrl(wn), . . . , ctrl(w1), ctrl(v)〉∈Ti iff there exists v∈V` having a port p such that link`(p) = link`(x′i), and there exist w1, . . . , wn ∈V` and a root k such that prnt`( j) = w1, prnt`(wz) = wz+1 (z = 1, . . . , n−1), prnt`(wn) = k. We write a ↓dI X′ to denote that X′ is a decorated IPO label for a. Barbed bisimulations about reactive systems with nested and multiple locations, where the role of a control depends also on its position (like e.g. in the case of web services), could benefit from the information about position of controls. An example of a name connected to a nested control is given in the case of Mobile Ambients (label in3 in Figure 10, Section 4). In the following, we will omit 〈−〉 on unary lists, we will write the pairs (x′i, Ti) as x′i(Ti), and we will consider a set like ⋃n−1 i=0 xi(Ti) also as the set defined as ⋃n−1 i=0 ⋃ t∈Ti xi(t). Definition 10 Given a BRS D(K , R) and ↓ be a predicate over bigraphical agents. A bigraph- ical barb bisimulation is a symmetric relation S , such that G S H then • if G ↓ X′ then H ↓ X′; • if G _ G′ then H _ H′ and G′S H′. The bigraphical barbed bisimilarity (∼) is the biggest bigraphical barbed bisimulation. The bigraphical barbed congruence (∼C) is the biggest congruence contained in bigraphical barbed bisimilarity. It can be defined by closing ∼ under all contexts, i.e., G ∼C H if for all contexts C, C◦G ∼C◦H. Notice that the closure under all contexts is necessary, because in general bigraphical barbed bisimilarities are not congruences (as usual with barbed bisimilarities). 3 Application: The π -calculus In this section we apply the theory of bigraphic barbed bisimilarity introduced in the previous section to the synchronous π -calculus. As a first step, we provide an encoding of the synchronous π -calculus as a BRS. This is almost the same as in [8]. We refer the reader to usual literature for the technical details about π -calculus e.g. [14]. 3.1 π -calculus Recall that the syntax of the (recursion-free) π -calculus is defined as follows: P, Q ::= 0 | z(x).P | z̄x.P | P|Q | ν x.P. Proc. Doctoral Symposium ICGT 2008 6 / 15 ECEASST Processes are taken up to the following structural equivalence (≡). P | 0 ≡ P P | Q ≡ Q | P (P | Q) | R ≡ P | (Q | R) ν x.0 ≡ 0 ν x.ν y.P ≡ ν y.ν x.P ν x.(P | Q) ≡ P | ν x.Q if x /∈ f n(P) ν x.z̄y.P ≡ z̄y.(ν x.P) if x /∈{z, y} ν x.z(y).P ≡ z(y).(ν x.P) if x /∈{z, y} The reduction semantics is defined by the following set of rules, closed under ≡: Com z̄x.P|z(y).Q → P|Q{x/y} P → Q P|R → Q|R P → Q ν x.P → ν x.Q A barb is a predicate over processes, it is usually written as P ↓ a, read P commits to a, where P is a process and a a name. Definition 11 Let ↓ be a barb predicate. A barbed bisimulation is a symmetric relation S , such that if P S Q, then • if P ↓ a, then Q ↓ a; • if P → P′, then Q → Q′ and P′S Q′. The barbed bisimilarity ( .∼) is the biggest barbed bisimulation. To obtain the biggest congruence, called barbed congruence ('c), contained into the barbed bisimilarity, we close .∼ under all contexts, i.e., P 'c Q if for all C[−] C[P] .∼C[Q]. In literature, two notions of barbs for the π -calculus have been introduced: Definition 12 Let P be a π -process, • (unsorted barbs) P commits to a (written P ↓π a) iff P ≡ a(b).Q | R or P ≡ āb.Q | R; • (sorted barbs) P commits to a (written P ↓π′ a) iff P ≡ a(b).Q | R and P commits to ā (written P ↓π′ ā) iff P ≡ āb.Q | R. We will denote with .∼π and 'cπ the barbed bisimilarity and barbed congruence for ↓π , respec- tively; and we will denote with .∼π′ and 'cπ′ the barbed bisimilarity and barbed congruence for ↓π′, respectively. The following result is well-known [14]: Proposition 2 'cπ = 'cπ′ ⊂ .∼π′ ⊂ .∼π . 3.2 π -calculus as BRS The signature for representing the π -calculus processes in binding bigraphs is Kπ , {get : 1 → 1, send : 0 → 2} where get and send are both passive. Notice that get has a binding port, representing the bound local variable. An example of the controls is given in Figure 3. 7 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems y x gety(x) y z sendyz Figure 3: The controls of the signature for the π -calculus. 0 y x0 z 1 0 y z x0 1 Comπ : getz(x) | sendzy → y/(x) | z | id1 | id1 ρ = id Figure 4: Reaction rules Rπ for the π -calculus. A π -process P is translated into a bigraph of BBG(Kπ ) as follows: J0KX = 1 | X JP | QKX = JPKX | JQKX Jν x.PKX = /x◦JPKX]{x} Jz(x).PKX = getz(x)◦JPKX]{x} if z∈X Jz̄x.PKX = sendzx ◦JPKX if z, x∈X The outer upward names represent free names; restricted names are encoded as edges; finally, input bindings are represented as binding ports localized in the get control. Proposition 3 (Syntax adequacy) Let P, Q be two π -processes and let X be a name set; then P ≡ Q iff JPKX = JQKX . The set of reaction rules (Rπ ) is shown in Figure 4. Notice that communication simply con- nects the links “stopped” by get to the resources provided by send. We denote this BRS as Dπ , D(Kπ , Rπ ), where the parametric rules can be instantiated with discrete bigraphs. Proposition 4 (Semantics adequacy) Let P, Q be two π -processes and let X be a name set; then P → Q iff JPKX _ JQKX . 3.3 Bigraphical barbed bisimilarity for π -calculus The IPO labels for the BRS Dπ are in Figure 5, and in Figure 6 we show the corresponding barbs (both bigraphic and decorated). Recalling that bigraphic barbs identify names on the agent interface which are “effectively involved” in reactions, an intuitive explanation of these barbs is the following. The barb a ↓I {y} on the left-hand side, arises from the fact that the agent uses Proc. Doctoral Symposium ICGT 2008 8 / 15 ECEASST Agent (a : ε → X ) Label conditions com1 /Z ◦(sendyx ◦d | q) gety(z)◦c y ∈ X and c discrete with names not in X ∪Z com2 /Z ◦(gety(x)◦d | q) sendyz ◦c y ∈ X and c discrete with names not in X ∪Z com3 /Z ◦((sendy0x ◦d) | (gety1(z)◦c) | q) id | w/y0 | w/y1 y0, y1 ∈ X com4 /Z ◦((sendyx ◦d) | (gety(z)◦c) | q) id - Figure 5: The set of labels for the π -calculus derived using the IPO construction. y xd q a ↓I {y} a ↓dI {y(send)} a y z c` q y z c a ↓I {y} a ↓dI {y(get)} y z xd y0 y1 z xd c q a ↓I {y0, y1} a ↓dI {y0(int), y1(int)} w z Figure 6: The barbs derived from the labels of Figure 5. y as input channel, and the IPO label completes the transition by providing an output along the same name. The same barb arises also in the second case; in order to distinguish the two labels, we have to consider also how the name y is used. In fact, the decorated barbs differ in these two cases, because they carry also the linking information about y in the IPO label. Finally, the third barb arises because the IPO label triggers a transition by unifying the channel names of the two controls; hence, in this case the two names are involved in an unification. Notice that the name z in the agent interface does not take part to the reactions, and hence it does not appear in the barbs. We will denote with .∼Iπ (resp. .∼dIπ ) the IPO barbed bisimilarity (resp. decorated IPO barbed bisimilarity), and with 'cIπ and 'cdIπ the corresponding congruences. Now we can state and prove some results on the derived barbed bisimilarities and congruences. Proposition 5 'cIπ = 'cdIπ = 'cπ = 'cπ′ ⊂ .∼π′ = .∼dIπ ⊂ .∼Iπ ⊂ .∼π . Proof. The equality 'cIπ = 'cdIπ = 'cπ = 'cπ′ is quite simple to prove. Just notice that all the extra information you can see in .∼π′ (discriminates by a and ā), .∼Iπ (can check if equating two names a process performs a communication), or .∼dIπ (can check communication enabling, as .∼Iπ , and besides it can see the nodes linked to the names inside the labels) w.r.t. .∼π are captured by the closure under all contexts. 9 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems The inclusion . . .'cπ′ ⊂ .∼π′. . . is trivially a consequence of Proposition 2. For .∼π′ = .∼dIπ , notice that every time a bigraph G G ↓dI {x(int), y(int)}, then either G ↓dI {x(send)} and G ↓dI y(get) or G ↓dI {x(get)} and G ↓dI y(send). For the barbs x(send) and x(get) there is a one to one correspondence with the barbs x and x̄, respectively. .∼dIπ ⊂ .∼Iπ because the former can observe the controls of nodes linked to names. The inclu- sion is strict, in fact Ja(x) | b̄zK .∼Iπ Jb(x) | āzK, but they are not decorated IPO barbed bisimilar. Finally, .∼Iπ ⊂ .∼π because there is a correspondence between the barb {x} used by .∼Iπ and the barb x in .∼π . The strictness of the inclusion is given by the fact that a(x) | b̄z .∼π āx | b̄z, but Ja(x) | b̄zK 6 .∼Iπ Jāx | b̄zK. IPO barbed bisimilarity is finer than (unsorted) bisimilarity due to the third barb in Figure 6, allowing to observe when the agent can perform an input and an output on two different names, at once. On the other hand, the decorated barb arising from this case does not add any discrim- inating power with respect to sorted barbed bisimilarity .∼π′, because the sorted barbs allow to observe when the agent exposes both an input and an output name. Finally, when we consider the contextual congruences of these bisimilarities, we get the same equivalence because any extra observations yielded by the (decorated) IPO barbs are recovered by suitable contexts. 4 Application: Mobile Ambients In this section we analyze another application of the theory of barbed bigraphical bisimilarity, i.e., to the fragment of recursion-free Mobile Ambients. The encoding resembles mostly the one presented in [7]. See [4] for a detailed introduction to Mobile Ambients. 4.1 Mobile Ambients Recall that the syntax of (our fragment of) Mobile Ambients is defined as follows: P, Q ::= 0 | n[P] | P|Q | ν n.P | in n.P | out n.P | open n.P. Processes are taken up to the following structural equivalence (≡): P | 0 ≡ P P | Q ≡ Q | P (P | Q) | R ≡ P | (Q | R) ν n.0 ≡ 0 ν n.ν m.P ≡ ν m.ν n.P ν n.(P | Q) ≡ P | ν n.Q if n /∈ f n(p) ν m.n[P] ≡ n[ν m.P] if m 6= n ν n.in m.P ≡ in m.ν x.P if n 6= m ν n.out m.P ≡ out m.ν n.P if n 6= m ν n.open m.P ≡ open m.ν x.P if n 6= m The reduction semantics is defined by the following set of rules, closed under ≡: In n[in m.P | Q] | m[R] → m[n[P | Q] | R] Out m[n[out m.P | Q] | R] → n[P | Q] | m[R] Open open n.P | n[Q] → P | Q P → Q P|R → Q|R P → Q ν x.P → ν x.Q P → Q n[P] → n[Q] As for π -calculus, we give a notion of barb for Mobile Ambients. It is defined as follows. Proc. Doctoral Symposium ICGT 2008 10 / 15 ECEASST n ambn n inn n outn n openn Figure 7: The controls of the signature for the Mobile Ambients. Definition 13 Let P be an ambient process. P commits to n (written P ↓A n) iff P ≡ n[Q] | R; We denote with .∼A and 'cA the barbed bisimilarity and barbed congruence for ↓A, respectively. 4.2 Mobile Ambients as BRSs The signature for representing the Mobile Ambients in binding bigraphs is KA , {amb : 0 → 1, in : 0 → 1, out : 0 → 1, open : 0 → 1} where amb is active and in, out, open are passive. An example of the controls is given in Figure 7. An ambient process P is translated into a bigraph of BBG(KA) as follows: J0KX = 1 | X JP | QKX = JPKX | JQKX Jν x.PKX = /x◦JPKX]{x} Jn[P]KX = ambn ◦JPKX if n ∈ X Jin n.PKX = inn ◦JPKX if n ∈ X Jout n.PKX = outn ◦JPKX if n ∈ X Jopen n.PKX = openn ◦JPKX if n ∈ X The outer upward names represent free names; restricted names are encoded as edges. Proposition 6 (Syntax adequacy) Let P, Q be two ambient processes and let X be a name set; then P ≡ Q iff JPKX = JQKX . The set of rules RA is shown in Figure 8. The first rule moves an ambient inside another one following the in capability; the second one moves an ambient outside another one by means of the capability out; finally the third rule open the ambient linked to the open capability. We denote this BRS as DA(KA, RA), whose parametric rules can be instantiated with discrete bigraphs. Proposition 7 (Semantics adequacy) Let P, Q be two ambient processes and let X be a name set; then P → Q iff JPKX _ JQKX . 4.3 Bigraphical barbed bisimilarity for Mobile Ambients Analogously to the π -calculus case, the set of labels derived by applying the IPO construction are shown in Figure 9; then, the derived barbs are shown in Figure 10. 11 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems 0 n m 0 1 2 0 n m 0 1 2 InA : (ambn ◦(inm | id1)) | ambm → (ambm ◦(ambn ◦(id1 | id1) | id1)) ρ = id 0 n m 0 1 2 0 n m 0 1 2 OutA : (ambm ◦(ambn ◦(outm | id1) | id1)) → (ambn ◦(id1 | id1)) | ambm ρ = id 0 n 0 1 0 n 0 1 OpenA : openn | ambn → id1 | id1 ρ = id Figure 8: Reaction rules RA for the Mobile Ambients. Barbs in3 and open1 let us to observe that n is the name of a top-level ambient (which can be entered, or opened, by a parallel agent). On the other hand, barbs in4, out3 and open3 arise from the IPO labels which trigger a reaction by unifying two names; notice that these names can be used at any position in the agent, not only at top level. Barbs in1 and in2, instead, arise when n is used by a “in” capability in the agent; in the first case, this capability is contained by an ambient at top-level, whilst in the second case the capa- bility is directly exposed at top-level. Interestingly, this topological difference is not observable in either kinds of IPO barbs. A similar situation holds for out1 and out2. Finally, open2 arises when n is a name used by an “open” capability at the top-level in the agent. We will denote with .∼IA (resp. .∼dIA) the IPO barbed bisimilarity (resp. decorated IPO barbed bisimilarity), and with 'cIA and 'cdIA the corresponding congruences. We can prove the following Proposition 8 1. .∼dIA ⊂ .∼IA ⊂ .∼A; 2. 'cdIA = 'cIA ⊂'cA; 3. .∼dIA 6⊂'cA and 'cA 6⊂ .∼IA; Proc. Doctoral Symposium ICGT 2008 12 / 15 ECEASST Agent (a : ε → X ) Label Conditions in1 /Z ◦(ambm ◦(inn ◦ p | q) | d) (ambn ◦c) | id n ∈ X and c discrete with names not in X∪Z in2 /Z ◦(inn ◦ p | q) ambn ◦ c | ambm ◦id n ∈ X , c discrete with names not in X ∪Z and m /∈ X ∪Z in3 /Z ◦(ambn ◦d | c) ambm ◦ (inn ◦ p | q) | id n ∈ X , p, q discretes with names not in X∪Z and m /∈ X ∪Z in4 T ◦(ambm ◦(inn0 ◦ p | q) | ambn1 ◦d) id | n/n0 | n/n1 n0, n1 ∈X and T active in5 T ◦(ambm ◦(inn ◦ p | q) | ambn ◦d) id T active out1 /Z ◦(ambm ◦(outn ◦ p | q) | d) ambn ◦(c | id) n ∈ X and c discrete with names not in X∪Z out2 /Z ◦(outn ◦ p | q) ambn ◦ ambm◦(c | id) n ∈ X , c discrete with names not in X ∪Z and m /∈ X ∪Z out3 T ◦ambn0 ◦(ambm ◦(outn1 ◦ p | q) | d) id | n/n0 | n/n1 n0, n1 ∈X and T active out4 T ◦ambn ◦(ambm ◦(outn ◦ p | q) | d) id T active open1 /Z ◦(ambn ◦ p | q) openn ◦c | id n ∈ X and c discrete with names not in X∪Z open2 /Z ◦(openn ◦ p | q) ambn ◦c | id n ∈ X and c discrete with names not in X∪Z open3 T ◦(openn0 ◦ p | ambn1 ◦q | d) id | n/n0 | n/n1 n0, n1 ∈X and T active open4 T ◦(openn ◦ p | ambn ◦q | d) id T active Figure 9: The set of labels for Mobile Ambients derived using IPO construction. Proof. 1. The first inclusion is justified by the fact that decorated IPO barbs are the same as the IPO barbs, but the former barbs have some extra information, so they are able to distinguish more than the latter ones. It is strict, consider in n and n[] as shown in Figure 6, Jin nK ↓I {n} and Jn[]K ↓I {n}, but Jin nK ↓dI {n(amb)} and Jn[]K ↓dI {n(〈amb, in〉)}. The second inclusion holds because the set of barbs of BA is a subset of the set of IPO barbs. To prove the strictness consider open n and open m, open n .∼A open m because they do nothing, but Jopen nK 6 .∼IA Jopen mK because Jopen nK ↓I {n} but Jopen mK ↓I {m}. 2. The equality is justified by the fact that the closure by all contexts catch all the extra information added by the decoration of IPO barbs. The inclusion is a direct consequence of point 1. It is strict, consider ν n.n[open m | k[]] and ν n.n[], they are barbed congruent, but not IPO barbed bisimilar, indeed Jν n.n[open m | k[]]K ↓I {k, m} and Jν n.n[]K 6↓I {k, m}. 3. .∼dIA 6⊂'cA is trivial, consider m[n[]] and m[k[]]: their encodings under J−K are decorated IPO bisimilar, but they are not barbed congruent. For 'cA 6⊂ .∼IA consider again ν n.n[open m | k[]] and ν n.n[]: they are barbed congruent, but not IPO barbed bisimilar, indeed Jν n.n[open m | k[]]K ↓I {k, m} and Jν n.n[]K 6↓I {k, m}. Intuitively, IPO barbed bisimilarity is finer than barbed bisimilarity because IPO barbs can 13 / 15 Volume 16 (2009) Deriving Barbed Bisimulations for Bigraphical Reactive Systems Rule IPO barb Decorated IPO barb in1 {n} {n(amb)} in2 {n} {n(amb)} in3 {n} {n(〈amb, in)〉} in4 {n0, n1} {n0(int), n1(int)} out1 {n} {n(amb)} out2 {n} {n(amb)} out3 {n0, n1} {n0(int), n1(int)} open1 {n} {n(open)} open2 {n} {n(amb)} open3 {n0, n1} {n0(int), n1(int)} Figure 10: The barbs derived from the labels in Figure 9. observe names of ambients together with names in capabilities, which may be not at the top level of the agent; these barbs arise from the fact that an unification of these names will trigger a reac- tion; see e.g. the counterexample given in the proof of Proposition 8.2. Notice that the contextual closures of these bisimilarities still do not coincide, because there is no ambient context which can observe inside a restricted ambient, like in the example above. 5 Conclusions In this paper we have presented a general notion of barb and barbed bisimilarity for bigraphical reactive systems. Intuitively, barbs are the names in the interfaces of an agent which are effec- tively involved in reactions. We have shown how these names can be found by looking inside the contextual labels of the agent given by the IPO construction. Also, a finer notion of barb (called “decorated”) can be defined by observing also how the names are used by the agent. The role played by a name can be figured out by looking at the controls it is connected to, in the IPO label. As example applications of this new notion of bisimilarity, we have considered the IPO barbed bisimilarities for the (BRS encodings of) π -calculus and Mobile Ambients. For π -calculus, IPO barbed bisimilarity is finer than standard barbed bisimilarity, but decorated IPO barbed bisim- ilarity coincides with sorted bisimilarity, and IPO barbed congruence coincides with standard barbed congruence. For Mobile Ambients, IPO barbed bisimilarities and congruence are finer than their standard counterparts. This is because IPO labels allow to observe also names used in inner capabilities and ambients, and not only names of top-level ambients. The problem of providing an abstract definition of barbs has been faced also in [13]. There, a general definition of barb is given around a notion of closure of an agent, that is, a minimal set of processes which offer an immediate interaction with the agent. Although this notion of closure seems related to the IPO construction used in the present work, their development is carried out in the quite different setting of biorthogonality. A future work will be to compare the IPO bigraphical barbs and those coming from the biorthogonality framework. Another interesting application of the IPO construction to barbed bisimilarities has been in- Proc. Doctoral Symposium ICGT 2008 14 / 15 ECEASST vestigated in [3], where the notion of barbed semisaturated bisimulation is introduced. Although it turns out to be finer than usual barbed congruence, this bisimulation is a congruence without the need of contextual closures, and moreover it can be characterized using the minimal labels defined by the IPO construction. However, [3] does not specify any particular notion of barb, and hence it can be seen as an complementary research with respect to our work. Finally, we plan to apply this theory to other calculi, such as Fusion calculus and those for security aspects (such as spi-calculus). To this end, the bigraphical barbed bisimilarity can be extended easily to directed bigraphs [5], which allow to represent also calculi with fusions. Bibliography [1] L. Birkedal, T. C. Damgaard, A. J. Glenstrup, and R. Milner. Matching of bigraphs. Electr. Notes Theor. Comput. Sci., 175(4):3–19, 2007. [2] L. Birkedal, S. Debois, E. Elsborg, T. Hildebrandt, and H. Niss. Bigraphical models of context-aware systems. In Proc. FoSSaCS, volume 3921 of LNCS, pages 187–201. Springer, 2006. [3] F. Bonchi, F. Gadducci, and G. V. Monreale. Reactive systems, barbed semantics, and the mobile ambients. In Proc. FOSSACS, LNCS. Springer-Verlag, 2009. [4] L. Cardelli and A. D. Gordon. Mobile ambients. In Proc. FOSSACS, pages 140–155. Springer-Verlag, Berlin Germany, 1998. [5] D. Grohmann and M. Miculan. Reactive systems over directed bigraphs. In Proc. CON- CUR, volume 4703 of LNCS, pages 380–394. Springer-Verlag, 2007. [6] O. H. Jensen. Bigraphs and weak bisimilarity. Talk at Dagstuhl Seminar 04241, June 2004. [7] O. H. Jensen. Mobile Processes in Bigraphs. PhD thesis, University of Aalborg, 2008. [8] O. H. Jensen and R. Milner. Bigraphs and transitions. In Proc. POPL, pages 38–49, 2003. [9] O. H. Jensen and R. Milner. Bigraphs and mobile processes (revised). Technical report UCAM-CL-TR-580, Computer Laboratory, University of Cambridge, 2004. [10] J. J. Leifer and R. Milner. Deriving bisimulation congruences for reactive systems. In Proc. CONCUR, volume 1877 of LNCS, pages 243–258. Springer, 2000. [11] J. J. Leifer and R. Milner. Transition systems, link graphs and petri nets. Mathematical Structures in Computer Science, 16(6):989–1047, 2006. [12] R. Milner. Bigraphical reactive systems. In Proc. 12th CONCUR, volume 2154 of LNCS, pages 16–35. Springer, 2001. [13] J. Rathke, V. Sassone, and P. Sobocinski. Semantic barbs and biorthogonality. In Proc. FoS- SaCS, volume 4423 of LNCS, pages 302–316. Springer, 2007. [14] D. Sangiorgi and D. Walker. The π -calculus: a Theory of Mobile Processes. CUP, 2001. 15 / 15 Volume 16 (2009) Introduction Barbed bisimilarities for Binding Bigraphs Binding Bigraphs Bigraphical reactive systems Minimal labels for BRSs Defining barbs from IPO labels Application: The -calculus -calculus -calculus as BRS Bigraphical barbed bisimilarity for -calculus Application: Mobile Ambients Mobile Ambients Mobile Ambients as BRSs Bigraphical barbed bisimilarity for Mobile Ambients Conclusions