ebook img

Parallel Graph Rewriting with Overlapping Rules PDF

1.1 MB·
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Parallel Graph Rewriting with Overlapping Rules

Parallel Graph Rewriting with Overlapping Rules Rachid Echahed1 and Aude Maignan2 1 LIG - CNRS and Universit´e de Grenoble Alpes, France [email protected] 2 LJK - Universit´e de Grenoble Alpes and CNRS, France [email protected] Abstract We tackle the problem of simultaneous transformations of networks represented as 7 graphs. Roughly speaking, one may distinguish two kinds of simultaneous or parallel 1 rewriterelationsovercomplexstructuressuchasgraphs: (i)thosewhichtransformdisjoint 0 subgraphs in parallel and hence can be simulated by successive mere sequential and local 2 transformations and (ii) those which transform overlapping subgraphs simultaneously. In the latter situations, parallel transformations cannot be simulated in general by means n a of successive local rewrite steps. We investigate this last problem in the framework of J overlappinggraphtransformationsystems. Asparalleltransformationofagraphdoesnot 4 produce a graph in general, we propose first some sufficient conditions that ensure the 2 closure of graphs by parallel rewrite relations. Then we mainly introduce and discuss two parallel rewrite relations over graphs. One relation is functional and thus deterministic, ] the other one is not functional for which we propose sufficient conditions which ensure its L confluence. F . s c 1 Introduction [ 1 Graphstructuresarefundamentaltoolsthathelpmodelingcomplexsystems. Inthispaper,we v are interested in the evolution of such structures whenever the dynamics is described by means 0 ofsystemsofrewriterules. Rewritingtechniquesarebeinginvestigatedfordifferentstructures 9 such as strings [4], trees [1] or graphs [20]. Roughly speaking, a rewrite rule can be defined as 7 a pair l→r where the left-hand and the right-hand sides are of the same structure. A rewrite 6 0 system, consisting of a set of rewrite rules, induces a rewrite relation (→) over the considered . structures. The rewrite relation corresponds to a sequential application of the rules, that is to 1 say, a structure G rewrites into a structure G(cid:48) if there exits a rule l → r such that l occurs in 0 7 G. Then G(cid:48) is obtained from G by replacing l by r. 1 Besides this classical rewrite relation, one may think of a parallel rewrite relation which : rewrites a structure G into a structure G(cid:48) by firing, simultaneously, some rules whose left-hand v i sides occur in G. Simultaneous or parallel rewriting of a structure G into G(cid:48) can be used as a X meanstospeedupthecomputationsperformedbyrewritesystemsand, insuchacase, parallel r rewritingcanbesimulatedbysuccessivesequentialrewritesteps. However,therearesituations a whereparallelrewritestepscannotbesimulatedbysequentialstepsasinformalgrammars[11], cellular automata (CA) [23] or L-systems [19]. This latter problem is of interest in this paper in the case where structures are graphs. Graphrewritingisaveryactiveareawhereonemaydistinguishtwomainstreamapproaches, namely(i)thealgorithmicapproacheswheretransformationsaredefinedbymeansoftheactual actionsonehastoperforminordertotransformagraph,and(ii)thealgebraicapproacheswhere graphtransformationsaredefinedinanabstractlevelusingtoolsborrowedfromcategorytheory such as pushouts, pullbacks etc. [20]. In this paper, we introduce a new class of graph rewrite systems following an algorithmic approach where rewrite rules may overlap. That is to say, in ParallelGraphRewriting R.EchahedandA.Maignan the process of graph transformation, it may happen that some occurrences of left-hand sides of different rules can share parts of the graph to be rewritten. This overlapping of the left-hand sides, whichcanbeveryappealinginsomecases, turnsouttobeasourceofdifficultytodefine rigorously the notion of parallel rewrite steps. In order to deal with such a difficulty we follow the rewriting modulo approach (see, e.g. [16]) where a rewrite step can be composed with an equivalencerelation. Anothercomplicationcomesfromthefactthatagraphcanbereducedin parallelinastructurewhichisnotalwaysagraphbutratherastructurewecallpregraph. Thus, we propose sufficient conditions under which graphs are closed under parallel rewriting. The rewritesystemsweobtaingeneralizesomeknownmodelsofcomputationsuchasCA,L-systems and more generally substitution systems [23]. As a simple example illustrating this work, we may refer to mesh refinement [5] and adaptative mesh refinement (AMR) which constitute a very usefull technique in physics [3, 17], astrophysics [12, 6] or in biology [18]. Thepaperisorganizedasfollows. Thenextsectionintroducesthenotionsofpregraphsand graphsinadditiontosomepreliminaryresultslinkingpregraphstographs. InSection3,aclass of rewrite systems, called environment sensitive rewrite systems is introduced together with a parallel rewrite relation. We show that graphs are not closed under such rewrite relation and proposesufficientconditionsunderwhichtheoutcomeofarewritestepisalwaysagraph. Then, inSection4,wedefinetwoparticularparallelrewriterelations,oneperformsfullparallelrewrite steps whereas the second relation uses the possible symmetries that may occur in the rules and considers only matches up to automorphisms of the left-hand sides. Section 5 illustrates our framework through some examples. Concluding remarks and related work are given in Section 6. 2 Pregraphs and Graphs In this section we first fix some notations and give preliminary definitions and properties. 2A denotes the power set of A. A(cid:93)B stands for the disjoint union of two sets A and B. In the following,weintroducethenotionof(attributed)pregraphs,whichdenotesaclassofstructures we use to define parallel graph transformations. Elements of a pregraph may be attributed via a function λ which assigns, to elements of a pregraph, attributes in some sets which underly a considered attributes’ structure A. For instance A may be a Σ-algebra [21] or merely a set. Definition 1 (Pregraph). A pregraph H is a tuple H =(N ,P ,PN ,PP ,A ,λ ) such that : H H H H H H • N is a finite set of nodes and P is a finite set of ports, H H • PN is a relation PN ⊆P ×N , H H H H • PP is a symmetric binary relation on ports, PP ⊆P ×P , H H H H • A is a structure of attributes, H • λH is a function λH :PH (cid:93)NH →2AH such that ∀x∈NH (cid:93)PH,card(λH(x)) is finite. An element (p,n) in PN means that port p is associated to node n. An element (p ,p ) H 1 2 in PP means that port p is linked to port p . In a pregraph, a port can be associated (resp. H 2 linked) to several nodes (resp. ports). Example 1. Figure 1 shows an example of a pregraph where the node attributes are natural numbers and Figure 2 shows an example where attributes could be expressions such as x+y. 2 In Figure 3, node attributes are variables ranging over N. The introduction of variables as attributes allows one to model node neighborhood-sensitive dynamics at the rewriting rule level as it will be illustrated in Section 5. 2 ParallelGraphRewriting R.EchahedandA.Maignan Figure 1: Example of a pregraph H such that: A = N, N = {n ,n ,n ,n ,n }, H H 1 2 3 4 5 P = {p ,p ,p }, PN = {(p ,n ),(p ,n ),(p ,n ),(p ,n ),(p ,n )}, PP = H 1 2 3 H 1 1 1 2 2 5 3 3 3 4 H {(p ,p ),(p ,p ),(p ,p ),(p ,p )}. PP could be reduced to its non symmetric port-port con- 1 2 2 3 2 1 3 2 H nection {(p ,p ),(p ,p )}. λ (n ) = {1} for i ∈ {1,2,4,5}, λ (n ) = {2}. λ (p ) = ∅, for 1 2 2 3 H i H 3 H j j ∈{1,2,3}. Port attributes (∅) have not been displayed on the figure. Figure 2: Example of a pregraph H such that: A =(Q[x,y];+,/), N ={n ,n ,n }, P = H H 1 2 3 H {p ,p ,q ,q }, PN = {(q ,n ),(p ,n ),(q ,n ),(p ,n )}, PP reduced to its non symmetric 2 3 1 2 H 1 1 2 2 2 2 3 3 H port-port connection is PP = {(p ,q ),(p ,q )}. λ (n ) = {x}, λ (n ) = {(x + y)/2}, H 2 1 3 2 H 1 H 2 λ (n )={y}, λ (p )=λ (p )=∅, λ (q )=λ (q )=∅. H 3 H 2 H 3 H 1 H 2 Below we introduce the definition of graphs used in this paper. In order to encode classical graph edges between nodes, restrictions over port associations are introduced. Intuitively, an edge e between two nodes n and n will be encoded as two semi-edges (n ,p ) and (n ,p ) 1 2 1 1 2 2 with p and p being ports which are linked via an association (p ,p ). 1 2 1 2 Definition 2 (Graph). A graph, G, is a pregraph G=(N,P,PN,PP,A,λ) such that : (i) PN is a relation ⊆ P ×N which associates at most one node to every port1. That is to say, ∀p∈P,∀n ,n ∈N,((p,n )∈PN and(p,n )∈PN) =⇒ n =n . 1 2 1 2 1 2 (ii) PP isasymmetricbinaryrelation2 onports,PP ⊆P×P,suchthat∀p ,p ,p ∈P,((p ,p )∈ 1 2 3 1 2 PP and (p ,p )∈PP) =⇒ p =p and ∀p∈P,(p,p)(cid:54)∈PP. 1 3 2 3 The main idea of our proposal is based on the use of equivalence relations over nodes and ports (merging certain nodes and ports under some conditions) in order to perform parallel graph rewriting in presence of overlapping rules. Thus, to a given pregraph H, we associate two equivalence relations on ports, ≡P, and on nodes, ≡N, as defined below. Definition 3 (≡P,≡N). Let H =(N ,P ,PN ,PP ,A ,λ ) be a pregraph. We define two H H H H H H relations ≡P and ≡N respectively on ports (P ) and nodes (N ) of H as follows: H H • ≡P is defined as (PP •PP )∗ H H • ≡N is defined as (PN−•≡P •PN)∗ H 1TherelationPN couldbeseenasapartialfunctionPN :P →N whichassociatestoagivenportp,anode n,PN(p)=n;thusbuildingasemi-edge“port-node”. 2The relation PP could also be seen as an injective (partial) function from ports to ports such that ∀p ∈ P,PP(p)(cid:54)=pand∀p1,p2∈P,PP(p1)=p2 iffPP(p2)=p1. 3 ParallelGraphRewriting R.EchahedandA.Maignan Figure 3: Example of a pregraph H such that: A = {N ∪ {x ,x ,x ,x ,x },+,×,= H 1 2 3 4 5 ? =}, N = {n ,n ,n ,n ,n }, P = {p ,p ,p ,p ,q ,q ,q ,q }, PN = H 1 2 3 4 5 H 2 3 4 5 2 3 4 5 H {(p ,n ),(p ,n ),(p ,n ),(p ,n ),(q ,n ),(q ,n ),(q ,n ),(q ,n )}, PP reduced to its non 2 1 3 1 4 1 5 1 2 2 3 3 4 4 5 5 H symmetric port-port connection is PP = {(p ,q ),(p ,q ),(p ,q ),(p ,q )}. λ (n ) = {x } H 2 2 3 3 4 4 5 5 H i i for i∈{1,2,3,4,5}, λ (p )=λ (q )=∅, for j ∈{2,3,4,5}. H j H j where • denotes relation composition, − the converse of a relation and ∗ the reflexive-transitive closureofarelation. Wewrite[n](respectively,[p])theequivalenceclassofnoden(respectively, port p). Roughlyspeaking,relation≡P istheclosureofthefirstpartofcondition(ii)inDefinition2. The base case says that if two ports p and p are linked to a same port p, then p and p are 1 2 1 2 considered to be equivalent. ≡N is almost the closure of condition (i) in Definition 2. That is, two nodes n and n , which are associated to a same port (or two equivalent ports), are 1 2 considered as equivalent nodes. Proposition 1. Let H =(N ,P ,PN ,PP ,A ,λ ) be a pregraph. The relations ≡P and H H H H H H ≡N are equivalence relations. Proof. The reflexivity and transitivity of ≡P and ≡N follow directly from their respective definitions. The symmetry of PP implies directly the symmetry of ≡P and ≡N. H Remark 1. The relations ≡P and ≡N can be computed incrementally as follows: Base cases: ≡P={(x,x)|x∈P } and ≡N={(x,x)|x∈N } 0 H 0 H Inductive steps: Rule I: if q,q(cid:48) ∈P such that, q ≡P q(cid:48), (q,p )∈PP and (q(cid:48),p )∈PP then p ≡P p . H i 1 H 2 H 1 i+1 2 Rule II: if p ∈P , p ∈P , (p ,n )∈PN , (p ,n )∈PN and p ≡P p then n ≡N n . 1 H 2 H 1 1 H 2 2 H 1 i 2 1 i+1 2 Rule III: If n ≡N n(cid:48) and n(cid:48) ≡N n then n ≡N n . 1 i i 2 1 i+1 2 Proposition 2. The limit of the series (≡P) is ≡P. i i≥0 Proof. Sincethesetofportsisfinitethenthelimitoftheseriesisreachedwithinafinitenumber of steps. ⇒ : Let p ,p ∈ P , such that p ≡P p for some k, let us prove by induction on k, that 1 2 H 1 k 2 (p ,p )∈(PP •PP)k. 1 2 • case k =0 : p ≡P p thus p =p and (p ,p )∈(PP •PP)0. 1 0 2 1 2 1 2 4 ParallelGraphRewriting R.EchahedandA.Maignan • Inductionstep,casek =k(cid:48)+1: Letusassumep ≡P p . Inthiscase,fromruleI,there 1 k(cid:48)+1 2 exist q,q(cid:48) ∈P such that, q ≡P q(cid:48), (q,p )∈PP and (q(cid:48),p )∈PP . q ≡P q(cid:48) implies by H k(cid:48) 1 H 2 H k(cid:48) induction hypothesis that (q,q(cid:48))∈(PP •PP)k(cid:48). Thus (p ,p )∈(PP •PP)k(cid:48)+1. 1 2 • Therefore for all k, p ≡P p implies (p ,p )∈(PP •PP)k, and thus, p ≡P p . 1 k 2 1 2 1 2 ⇐ Let p ≡P p . By definition of ≡P, there exists a natural number k such that (p ,p )∈ 1 2 1 2 (PP •PP)k. It is then straightforward that p ≡P p . 1 k 2 Likewise, we can easily show the following proposition regarding relation ≡N. Proposition 3. The limit of the series (≡N) is ≡N. i i≥0 Proof. Since the sets of nodes and ports are finite then the limit of the series is reached within a finite number of steps. ⇒ : Let n ,n ∈ N , such that n ≡N n for some k , let us prove 1 2 H 1 k 2 by induction on k, that (n ,n )∈≡N. 1 2 • case k =0 : obvious. • Inductionstep,casek =k(cid:48)+1: Letusassumen ≡N n . Wedistinguishtwosub-cases 1 k(cid:48)+1 2 according to the used rules, i.e. Rule II or Rule III. Rule III. AccordingtoRuleIII,thereexistsanoden(cid:48) suchthatn ≡N n(cid:48) andn(cid:48) ≡N n . From 1 k(cid:48) k(cid:48) 2 theinductionhypothesis,wehaven ≡N n(cid:48) =⇒ n ≡N n(cid:48) andn(cid:48) ≡N n =⇒ n(cid:48) ≡N 1 k(cid:48) 1 k(cid:48) 2 n . Then by transitivity of ≡N we have n ≡N n . 2 1 2 Rule II. AccordingtoRuleII,thereexisttwoportsp andp inP suchthat(p ,n )∈PN , 1 2 H 1 1 H (p ,n ) ∈ PN and p ≡P p . From Proposition 2, p ≡P p =⇒ p ≡P p , and 2 2 H 1 k(cid:48) 2 1 k(cid:48) 2 1 2 thus, there exists an index i such that (p ,p )∈(PP •PP )i. Since (p ,n )∈PN 1 2 H H 1 1 H and (p ,n )∈PN we conclude that (n ,n )∈(PN−•≡P •PN ) 2 2 H 1 2 H H ⇐ Let n ≡N n . Then by definition of ≡N there exists a natural number k such that 1 2 (n ,n ) ∈ (PN−• ≡P •PN )k. This means that there is a chain of connections consisting of 1 2 H H tuplesoftheform(m ,p ).p ≡P p(cid:48).(p(cid:48),m )fori∈{0,...,k}suchthatm =n andm =n . i i i i i i+1 0 1 k 2 From rule III, it is easy to deduce the existence of k(cid:48), such that n ≡N n . 1 k(cid:48) 2 Theequivalencerelations≡P and≡N areusedtointroducethenotionofquotientpregraph as defined below. Definition 4 (Quotient Pregraph). Let H =(N ,P ,PN ,PP ,A ,λ ) be a pregraph and H H H H H H ≡P and ≡N two equivalence relations over ports and nodes respectively. We write H the pre- graph H = (N ,P ,PN ,PP ,A ,λ ) where N = {[n] | n ∈ N }, P = {[p] | p ∈ P }, H H H H H H H H H H PN = {([p],[n]) | (p,n) ∈ PN }, PP = {([p],[q]) | (p,q) ∈ PP }, A = A and H H H H H H λ ([x])=∪ λ (x(cid:48)) where [x]∈N (cid:93)P H x(cid:48)∈[x] H H H Example 2. Let H = (N ,P ,PN ,PP ,A ,λ ) be a pregraph as depicted on the left of H H H H H H Figure 4, with N = {n ,n ,n ,n }, P = {p ,p ,p ,p ,p ,p }, PN = {(p ,n ),(p ,n ), H 1 2 3 4 H 1 2 3 4 5 6 H 1 1 5 1 (p ,n ),(p ,n ),(p ,n ),(p ,n )}, PP ={(p ,p ),(p ,p ),(p ,p ),(p ,p ),(p ,p )}, 2 2 6 2 4 3 3 4 H 1 2 1 4 2 3 3 4 5 6 A =N, λ (n )=λ (n )={1}, λ (n )=λ (n )={2}, ∀i∈{1,...,6},λ (p )=∅, H NH 1 NH 4 NH 2 NH 3 PH i We obtain H =(N ,P ,PN ,PP ,A ,λ ), as depicted on the right of Figure 4, with H H H H H H • N ={[n ],[n ]} with [n ]={n ,n }, [n ]={n ,n }, H 1 2 1 1 4 2 2 3 • P ={[p ],[p ],[p ],[p ]} with [p ]={p ,p }, [p ]={p ,p }, [p ]={p }, [p ]={p }, H 1 2 5 6 1 1 3 2 2 4 5 5 6 6 • PN ={([p ],[n ]),([p ],[n ]),([p ],[n ]),([p ],[n ])}, H 1 1 5 1 2 2 6 2 5 ParallelGraphRewriting R.EchahedandA.Maignan Figure 4: (a) A pregraph H (b) and its corresponding quotient pregraph H. • PP ={([p ],[p ]),([p ],[p ])}, H 1 2 5 6 • A =A H H • λ ([n ])={1}, λ ([n ])={2}, λ ([p ])=λ ([p ])=λ ([p ])=λ ([p ])=∅. N 1 N 2 P 1 P 2 P 5 P 6 H H H H H H Example 3. Figure 5 illustrates two computations of quotient pregraphs. Remark 2. If H is a graph, H and H are isomorphic. Indeed, in a graph, a port can be associated (resp. linked) to at most one node (resp. one port). The following definition introduces some vocabulary and notations. Definition 5 (Path, Loop). • A path π (p ,p ) between two (possibly the same) nodes p H 1 k 1 and p in a pregraph H is a sequence of ports of H written π (p ,p ) = (p ,p ,...,p ) k H 1 k 1 2 k such that {(p ,p )|i=1,2,...,k−1}⊆PP and k ∈N with k >0. i i+1 H • The length of a path π (p ,p )=(p ,p ,...,p ) is (cid:93)(π (p ,p ))=k−1. H 1 k 1 2 k H 1 k • An even path (resp. odd path) is a path such that its length is even (resp. odd). • A loop is a closed path, i.e., a path π =(p ,p ,...,p ) such that p =p . An even loop H 1 2 k 1 k (resp. odd loop) is an even closed path (resp. odd closed path). From the definitions above, one can show the following statements. Proposition 4. Let H = (N ,P ,PN ,PP ,A ,λ ) be a pregraph. Let q,q(cid:48) be two ports H H H H H H in P . q ≡P q(cid:48) iff there exists an even path between q and q(cid:48) in H. H Proof. If q ≡P q(cid:48) then, by definition, (q,q(cid:48)) ∈ (PP •PP )∗ hence there exists an even path H H between q and q(cid:48). Conversely, if there exists an even path between q and q(cid:48) in H then (q,q(cid:48))∈ (PP •PP )∗ and thus q ≡P q(cid:48). H H Proposition 5. Let H =(N ,P ,PN ,PP ,A ,λ ) be a pregraph. H is a graph iff H has H H H H H H no odd loop. Proof. Let H = (N ,P ,PN ,PP ,A ,,λ ). The relations PN and PP are functional H H H H H H H H by construction. In order to show that H is indeed a graph, It remains to prove that PP is H not anti-reflexive iff there is an odd loop in H. ⇒ AssumethatPP isnotanti-reflexive. Then,thereexistsq ∈P suchthat([q],[q])∈PP . H H H Thus, either (q,q) ∈ PP which constitute an odd loop of length one or there exists a H port q(cid:48), different from q, such that (q,q(cid:48)) ∈ PP and q(cid:48) ≡P q. In this last case, from H Proposition4, q(cid:48) ≡P q implies the existence of an even path from q(cid:48) to q. Then adding the link (q,q(cid:48)) to this path builds a loop from q to q in H of odd length. 6 ParallelGraphRewriting R.EchahedandA.Maignan Figure5: (a)ApregraphH anditscorrespondingquotientpregraphH whichisagraph. (b) 2 2 A pregraph H and its corresponding quotient pregraph H which is not a graph. 3 3 ⇐ Assume there is an odd loop containing a port q in H. Then either the loop is of the form (q,q) and thus (q,q)∈PP and in this case ([q],[q])∈PP , or there exists a port q(cid:48) H H different from q such that the loop is of the form (q,q(cid:48),...,q). In this last case, (q,q(cid:48)) ∈ PP and the path π (q(cid:48),q) is even. Thus, [q]=[q(cid:48)] which implies that ([q],[q])∈PP . H H H Below, we define the notion of homomorphisms of pregraphs and graphs. This notion assumes the existence of homomorphisms over attributes [7]. Definition 6 (Pregraph and Graph Homomorphism). Let l = (N ,P ,PN ,PP ,A ,λ ) and l l l l l l g = (N ,P ,PN ,PP ,A ,λ ) be two pregraphs. Let a : A → A be a homomorphism over g g g g g g l g attributes. A pregraph homomorphism, ha : l → g, between l and g, built over attribute homomorphism a, is defined by two functions ha : N → N and ha : P → P such that (i) N l g P l g ∀(p ,n ) ∈ PN , (ha(p ),ha (n )) ∈ PN , (ii) ∀(p ,p ) ∈ PP , (ha(p ),ha(p )) ∈ PP , (iii) 1 1 l P 1 N 1 g 1 2 l P 1 P 2 g ∀n ∈N ,a(λ (n ))⊆λ (ha (n )) and (iv) ∀p ∈P ,a(λ (p ))⊆λ (ha(p )). 1 l l 1 g N 1 1 l l 1 g P 1 A graph homomorphism is a pregraph homomorphism between two graphs. Notation: Let E be a set of attributes, we denote by a(E) the set a(E)={a(e)|e∈E}. Proposition 6. Let H and H(cid:48) be two isomorphic pregraphs. Then H and H(cid:48) are isomorphic. Proof. Let ha : H → H(cid:48) be a pregraph isomorphism. We define ha : H → H(cid:48) as follows: for all ports p,p(cid:48) in H, nodes n in H, ha ([n]) = [ha (n)], ha([p]) = [ha(p)], ha([p],[n]) = N N P P ([ha(p)],[ha (n)]), ha([p],[p(cid:48)])=([ha(p)],[ha(p(cid:48))]). P N P P ha is clearly a pregraph isomorphism between H and H(cid:48). h is well defined as illustrated in the following three items. • We show that for all ports p ,p in H, p ≡P p iff ha(p )≡P ha(p ) : 1 2 1 H 2 P 1 H(cid:48) P 2 ha(p ) ≡p ha(p ) iff there exists a path π (ha(p ),ha(p )) = (q ,q ,...q ,q ) such P 1 H(cid:48) P 2 H(cid:48) P 1 P 2 1 2 k−1 k that q =ha(p ), q =ha(p ) and (cid:93) (ha(p ),ha(p )) is even (see, Proposition 4). It is 1 P 1 k P 2 πH(cid:48) P 1 P 2 equivalent to say that (p ,(ha)−1(q ),...,(ha)−1(q ),p ) is an even path of H because 1 P 2 P k−1 2 h is an isomorphism. We conclude that p ≡p p . 1 H 2 • For all nodes n ,n in H, we show that n ≡n n iff ha (n )≡n ha (n ). 1 2 1 H 2 N 1 H(cid:48) N 2 By definition, ha (n )≡n ha (n ) iff (a) ha (n )=ha (n ) or (b) there exists q,q(cid:48) ∈P , N 1 H(cid:48) N 2 N 1 N 2 H(cid:48) q ≡p q(cid:48), (q,ha (n )) ∈ PN and (q(cid:48),ha (n )) ∈ PN or (c) there exists n(cid:48)(cid:48) ∈ N , H(cid:48) N 1 H(cid:48) N 2 H(cid:48) H(cid:48) ha (n )≡n n(cid:48)(cid:48) and ha (n )≡n n(cid:48)(cid:48). N 1 H(cid:48) N 2 H(cid:48) 7 ParallelGraphRewriting R.EchahedandA.Maignan ha is an isomorphism thus (a) is equivalent to n = n and (b) is equivalent to there 1 2 exists (ha)−1(q),(ha)−1(q(cid:48)) ∈ P , (ha)−1(q) ≡p (ha)−1(q(cid:48)), ((ha)−1(q),n ) ∈ PN P P H P H(cid:48) P P 1 H and ((ha)−1(q(cid:48)),n ) ∈ PN . The cases (a) and (b) are straight foward. Let us focus P 2 H our attention on the case (c) : ha (n ) ≡n ha (n ) such that it exists n(cid:48)(cid:48) ∈ N and N 1 H(cid:48) N 2 H(cid:48) q,q(cid:48) ∈ P which verify the condition {(q,n(cid:48)(cid:48)),(q,h(n )),(q(cid:48),n(cid:48)(cid:48)),(q(cid:48),ha (n ))} ⊂ PN . H(cid:48) 1 N 2 H(cid:48) This is equivalent to : (ha )−1(n(cid:48)(cid:48)) ∈ N and (ha)−1(q),(ha)−1(q(cid:48)) ∈ P which verify N H P P H the condition {((ha)−1(q),(ha)−1(n(cid:48)(cid:48))),((ha)−1(q),n ),((ha)−1(q(cid:48)),(ha )−1(n(cid:48)(cid:48))),((ha)−1(q(cid:48)),n )}⊂PN P P P 1 P N P 2 H and in that case n ≡N n . Moreover because ≡N is transitive we obtain that (c) is 1 H 2 equivalentto: thereexists(ha )−1(n(cid:48)(cid:48))∈N ,n ≡n (ha )−1(n(cid:48)(cid:48))andn ≡n (ha )−1(n(cid:48)(cid:48)). N H 1 H N 2 H N Thus, n ≡n n . 1 H 2 • The pregraph homorphism of H → H(cid:48) and H → H(cid:48) are built over the same attribute homomorphism a, thus by construction the points (iii) and (iv) of the previous definition imply ∪ a(λ (n ))⊂∪ λ (ha (n )) and ∪ a(λ (p ))⊂∪ λ (ha(p )) ni∈[n] H i ni∈[n] H(cid:48) N i pi∈[p] H i pi∈[p] H(cid:48) P i a a thus a(λ ([n])) ⊂ λ (h ([n])) and a(λ ([p])) ⊂ λ (h ([p])) and ha is a pregraph H H(cid:48) N H H(cid:48) P (cid:48) homomorphism from H to H . We end this section by defining an equivalence relation over pregraphs. Definition 7 (Pregraph equivalence). Let G and G be two pregraphs. We say that G and 1 2 1 G are equivalent and write G ≡G iff the quotient pregraphs G and G are isomorphic. 2 1 2 1 2 The relation ≡ over pregraphs is obviously an equivalence relation. 3 Graph Rewrite Systems In this section, we define the considered rewrite systems and provide sufficient conditions en- suring the closure of graph structures under the defined rewriting process. Definition 8 (Rewrite Rule, Rewrite System, Variant). A rewrite rule is a pair l → r where l and r are graphs over the same sets of attributes. A rewrite system R is a set of rules. A variant of a rule l → r is a rule l(cid:48) → r(cid:48) where nodes, ports as well as the variables of the attributes are renamed with fresh names. Let l(cid:48) → r(cid:48) be a variant of a rule l → r. Then there is a renaming mapping ha, built over an attribute renaming a : A → A , and consisting of two maps ha and ha over nodes and l l(cid:48) N P ports respectively : ha : N ∪N → N ∪N and ha : P ∪P → P ∪P such that, the N l r l(cid:48) r(cid:48) P l r l(cid:48) r(cid:48) elements in N and P are new and the restrictions of ha to l → l(cid:48) (respectively r → r(cid:48)) are l(cid:48) r(cid:48) graph isomorphisms. Ingeneral,partsofaleft-handsideofaruleremainunchangedintherewritingprocess. This feature is taken into account in the definition below which refines the above notion of rules by decomposingtheleft-handsidesintoanenvironmental part,intendedtostayunchanged,anda cut partwhichisintendedtoberemoved. Asfortheright-handsides,theyarepartitionedinto a new part consisting of added items and an environmental part (a subpart of the left-hand side) which is used to specify how the new part is connected to the environment. Definition 9 (Environment Sensitive Rewrite Rule, Environment Sensitive Rewrite System). An environment sensitive rewrite rule is a rewrite rule (ESRR for short) l → r where l and r are graphs over the same attributes A such that: 8 ParallelGraphRewriting R.EchahedandA.Maignan - l=(N ,P ,PN ,PP ,A,λ ) where l l l l l N =Ncut(cid:93)Nenv,P =Pcut(cid:93)Penv,PN =PNcut(cid:93)PNenv,PP =PPcut(cid:93)PPenvandλ =λcut(cid:93)3 l l l l l l l l l l l l l l λenv with some additional constraints : l (1) on PN : ∀(p,n)∈PN ,(n∈Ncut or p∈Pcut)⇒(p,n)∈PNcut. l l l l l (2) on PP : ∀(p,p(cid:48))∈PP ,p∈Pcut ⇒(p,p(cid:48))∈PPcut. l l l l (3) on λ : ∀n∈Ncut,(n,λ (n))∈λcut and ∀p∈Pcut,(p,λ (p))∈λcut. l l l l l l l - r =(N ,P ,PN ,PP ,A,λ ) where r r r r r N = Nnew (cid:93)Nenv,P = Pnew (cid:93)Penv,PN = PNnew (cid:93)PNenv,PP = PPnew (cid:93)PPenv,λ = r r r r r r r r r r r r r λnew (cid:93)λenv such that Nenv ⊆ Nenv, Penv ⊆ Penv, Nnew ∩Nenv = ∅ and Pnew ∩Penv = ∅ r r r l r l r l r l with some additional constraints : (4) on PN : ∀(p,n)∈PN ,(p,n)∈PNenv iff (p∈Penv and n∈Nenv and (p,n)∈PNenv). r r r r r l (5) on PP : ∀(p,p(cid:48))∈PP ,(p,p(cid:48))∈PPenv iff (p∈Penv and p(cid:48) ∈Penv and (p,p(cid:48))∈PPenv). r r r r r l (6) on λ : ∀n∈Nenv,(∃y,(n,y)∈λenv) iff (λenv(n)=λenv(n)) ; r r r r l ∀y ∈Penv,(∃y,(p,y)∈λenv) iff (λenv(p)=λenv(p)). r r r l An environment sensitive rewrite system (ESRS for short) is a set of environment sensitive rewrite rules. Roughly speaking, constraints (1), (2) and (3) ensure that if an item (node or port) is to be removed(belongingtoa“cut”component)thenlinksinvolvingthatitemshouldberemovedtoo as well as its attributes (constraint (3)). Constraints (4) and (5) ensure that links, considered asnew(belongingto“new”components),ofagivenright-handsideofarule,shouldnotappear in the left-hand side. Constraint (6) ensures that an item (node or port) is newly attributed in the right-hand side iff it is a new item or it was assigned by λcut in the left-hand side. l Proposition 7. Let l → r be a an ESRR such that l = (N = Ncut (cid:93)Nenv,P = Pcut (cid:93) l l l l l Penv,PN =PNcut(cid:93)PNenv,PP =PPcut(cid:93)PPenv,A,λ =λcut(cid:93)λenv) and r =(N =Nnew(cid:93) l l l l l l l l l l r r Nenv,P =Pnew(cid:93)Penv,PN =PNnew(cid:93)PNenv,PP =PPnew(cid:93)PPenv,A,λ =λnew(cid:93)λenv). r r r r r r r r r r r r r Then the following properties hold: • Forall(p,n)∈PN ,(p,n)∈PNnew iffp∈Pnew orn∈Nnew or(p∈Penv andn∈Nenv r r r r r r and (p,n)(cid:54)∈PNenv) l • Forall(p,p(cid:48))∈PP ,(p,p(cid:48))∈PPnew iffp∈Pnew orp(cid:48) ∈Pnew or(p∈Penv andp(cid:48) ∈Penv r r r r r r and (p,p(cid:48))(cid:54)∈PPenv(p)) l • For all x∈N ∪P , (x,λ (x))∈λnew iff x∈Nnew∪Pnew or (x,λ (x))∈λcut r r r r r r l l Example 4. Let us consider a rule R : l → r which specifies a way to transform a tri- T angle into four triangle graphs. Figure 6 depicts the rule. Black parts should be understood as members of the cut component of the left-hand side, yellow items are in the environ- ment parts. The red items are new in the right-hand side. More precisely, lenv consists of Nenv = {α,β,γ}, Penv = {α ,α ,β ,β ,γ ,γ }, PNenv = {(α ,α),(α ,α),(β ,β),(β ,β), l l 1 2 1 2 1 2 l 1 2 1 2 (γ ,γ),(γ ,γ)}, and PPenv =∅. The cut component of the left-hand side consists of three port- 1 2 l port connections and their corresponding symmetric connections which will not be written : PPcut ={(α ,β ),(β ,γ ),(γ ,α )}. The environment component in the right-hand side allows l 2 1 2 1 2 1 toreconnectthenewlyintroduceditems. renv consistsoftheportsPenv ={α ,α ,β ,β ,γ ,γ }. r 1 2 1 2 1 2 rnew consists of Nnew ={U,V,W}, Pnew ={u ,u ,u ,u ,v ,v ,v ,v ,w ,w ,w ,w }, r r 1 2 3 4 1 2 3 4 1 2 3 4 3Here,thefunctionλ isconsideredasasetofpairs(x,λ(x)),i.e. thegraphofλ. l l l 9 ParallelGraphRewriting R.EchahedandA.Maignan Figure 6: Rule R T Figure 7: (a) A graph l. (b) A graph g. PNnew ={(u ,U),(u ,U),(u ,U),(u ,U),(v ,V),(v ,V),(v ,V),(v ,V),(w ,W),(w ,W), r 1 2 3 4 1 2 3 4 1 2 (w ,W),(w ,W)} and PPnew ={(α ,w ),(α ,u ),(β ,u ),(β ,v ),(γ ,v ),(γ ,w ),(u ,w ), 3 4 r 1 2 2 1 1 2 2 1 1 2 2 1 3 3 (u ,v ),(w ,v )}. The sets of attributes are empty in this example. 4 4 4 3 Remark 3. From the definition of an environment sensitive rule, the environment components renv =(Nenv,Penv,PNenv,PPenv,A,λenv) and lenv =(Nenv,Penv,PNenv,PPenv,A,λenv) are r r r r r l l l l l graphs. However, since PPcut may include ports in Penv and PNcut may include nodes in Nenv l l l l or ports in Penv, the cut component lcut = (Ncut,Pcut,PNcut,PPcut,A,λcut) is in general l l l l l l neither a graph nor a pregraph. For the same reasons rnew =(Nnew,Pnew,PNnew,PPnew, r r r r A,λnew) is in general neither a graph nor a pregraph. r Findinganoccurrenceofaleft-handsideofarulewithinagraphtobetransformedconsists in finding a match. This notion is defined below. Definition 10 (Match). Let l and g be two graphs. A match ma : l → g is defined as an injective graph homomorphism. a:A →A being an injective homomorphism over attributes. l g Example 5. Figure 7 gives a graph l and a graph g. Because of ports attributes, only two matches, mid and mid can be defined from l to g: 1 2 • mid : mid(α) = E;mid(β) = B; mid(γ) = C; mid(α ) = e ;mid(α ) = e ;mid(β ) = 1 1 1 1 1 1 1 1 2 2 1 1 b ;mid(β )=b ; mid(γ )=c ; mid(γ )=c . 1 1 2 2 1 1 1 1 2 2 • mid : mid(α) = C;mid(β) = D; mid(γ) = F; mid(α ) = c ;mid(α ) = c ;mid(β ) = 2 2 2 2 2 1 3 2 2 4 2 1 d ;mid(β )=d ; mid(γ )=f ; mid(γ )=f . 1 2 2 2 2 1 1 2 2 2 Notice that the occurrences in g of mid(l) and mid(l) overlap on node C. 1 2 10

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.