A Note on Causalities in Reaction Systems Electronic Communications of the EASST Volume 30 (2010) International Colloquium on Graph and Model Transformation On the occasion of the 65th birthday of Hartmut Ehrig (GraMoT 2010) A Note on Causalities in Reaction Systems Robert Brijder, Andrzej Ehrenfeucht, and Grzegorz Rozenberg 9 pages Guest Editors: Claudia Ermel, Hartmut Ehrig, Fernando Orejas, Gabriele Taentzer 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 A Note on Causalities in Reaction Systems Robert Brijder∗1, Andrzej Ehrenfeucht2, and Grzegorz Rozenberg1 2 1 Leiden Institute of Advanced Computer Science, Leiden Center for Natural Computing, Leiden University, The Netherlands 2 Department of Computer Science, University of Colorado at Boulder, USA Abstract: Reaction systems are a formal model of interactions between biochemical reactions. In this note we initiate an investigation of causalities in reaction systems which reflect the way that elements (entities) of a reaction system influence each other. Keywords: natural computing; biochemical interactions; reaction systems; causal relationships 1 Introduction Reaction systems are a formal model of interactions between biochemical reactions which is based on the idea that the underlying mechanisms of these interactions as well as the working of an individual reaction are: facilitation and inhibition. Therefore a reaction is defined as a triplet of finite nonempty sets a = (R,I,P), where R is the set of reactants needed for a to take place, I is the set of inhibitors each of which forbids a to take place, and P is the set of products produced by a when it takes place. The set R∪I forms the resources of a — these are all entities that directly influence a either as reactants or as inhibitors. Reactions (of a given biochemical system) influence each other through their products — they may contain entities which are reactants for some reactions (therefore facilitating these reactions) and they may contain entities which are inhibitors for some reactions (therefore inhibiting these reactions). A reaction system A = (S,A) consists of a finite set of reactions A and a finite background set of entities used in reactions of A and entities needed to analyze the functioning of A . Research concerning reaction systems is quite broad. For example, it covers fundamental issues such as the notion of time in reaction systems ([ER09]), it is concerned with the dynamic processes in reaction systems and the way these processes guide the formations of compounds ([ER07a]), and it investigates the mathematical nature of functions (from states to states, and hence from finite sets into finite sets) definable by reaction systems ([EMR10]). In this note we initiate research on causalities in reaction systems, i.e., the ways that entities of a reaction system influence each other. We discuss here both static/structural causalities (i.e., embedded directly in the definition/specification of a reaction system) as well as dynamic causalities (i.e., the relationships formed through the dynamic runs of a reaction system). ∗ Supported by the Netherlands Organization for Scientific Research (NWO), project “Annotated graph mining”. 1 / 9 Volume 30 (2010) A Note on Causalities in Reaction Systems 2 Preliminaries In order to fix notation and terminology, we recall in this section some basic notions concerning sets and graphs. As usual, Z+ is the set of positive integers, and we let ω be the cardinality of Z+. The symmetric difference of sets Z1 and Z2, defined by (Z1 \Z2)∪(Z2 \Z1), is denoted by Z1 ⊕Z2. For a nonempty U ⊆Z+, the minimal integer of U is denoted by min(U). Let τ = W0,...,Wn be a sequence of sets. For a set S, we say that τ is an S-sequence if Wi ⊆ S for all i ∈{0,...,n}. We denote the length of τ by |τ| (note that |τ| = n + 1). For a set Q, the Q-projection of τ is the Q-sequence of sets projQ(τ) = W0 ∩Q,...,Wn ∩Q. A directed graph (digraph) is an ordered pair G = (V,E), where V is a finite set of vertices, and E ⊆ V ×V is the set of edges. Note that we allow loops (x,x) ∈ E. For x ∈ V , y ∈ V is an outgoing (incoming, resp.) vertex of x if (x,y) ∈ E ((y,x) ∈ E, resp.). The set of outgoing (incoming, resp.) vertices of x is denoted by outG(x) (incG(x), resp.). The out-degree (in-degree, resp.) of x, denoted by odG(x) (idG(x), resp.), is the number of outgoing (incoming, resp.) vertices of x, i.e., it equals |outG(x)| (|incG(x)|, resp.). 3 Reactions and Reaction Systems In this and in the following section we recall the basic notions related to reaction systems (see, e.g., [ER07b]). Definition 1 A reaction is a triplet a = (R,I,P), where R,I,P are finite nonempty sets such that R∩I = ∅. The sets R,I,P are also denoted by Ra,Ia,Pa, and called the reactant set of a, the inhibitor set of a, and the product set of a, respectively. Also, Ma = Ra ∪Ia is the set of resources of a. If S is a set such that R,I,P ⊆ S, then a is a reaction in S, and rac(S) denotes the set of all reactions in S. Definition 2 Let T be a finite set. 1. Let a be a reaction. Then a is enabled by T , denoted by a en T , if Ra ⊆ T and Ia ∩T = ∅. The result of a on T , denoted by resa(T ), is defined by: resa(T ) = Pa if a en T , and resa(T ) = ∅ otherwise. 2. Let A be a finite set of reactions. The result of A on T , denoted by resA(T ), is defined by: resA(T ) = ⋃ a∈A resa(T ). The intuition behind the finite set T above is that it represents a state of a biochemical system (hence it is the set of biochemical entities present in this state). A reaction a is enabled in T (it will take place in T ) if all of its reactants are present in T while none of its inhibitors are in T . This is the reason that we assume in Definition 1 that, for each reaction a, Ra ∩Ia = ∅, as otherwise a is never enabled. When a takes place it produces entities from Pa. The effect of a set of reactions A is cumulative — the result of A on T consists of all products of all reactions from Proc. GraMoT 2010 2 / 9 ECEASST A that are enabled on T . Example 1 Let S = {s1,s2,s3,s4}, a1 = ({s2},{s1,s4},{s2}), and a2 = ({s2,s3}, {s1},{s3}). Then a1,a2 ∈ rac(S) and, e.g., Ma1 = {s1,s2,s4} and Pa1 = {s2}. We have for A = {a1,a2}, resA({s2,s3}) ={s2,s3}. We are ready now to recall the notion of a reaction system. Definition 3 A reaction system, rs for short, is an ordered pair A = (S,A) such that S is a finite set, and A ⊆ rac(S). The set S is called the background set of A , its elements are called entities, and A is called the set of reactions of A — note that since S is finite, so is A. The dynamic behavior of a rs is formalized through the notion of an interactive process. Definition 4 Let A = (S,A) be a rs. An (n-step) interactive process in A is a pair π = (γ,δ ) of finite equal length S-sequences γ = C0,...,Cn and δ = D0,...,Dn for some n ≥ 1, where D0 = ∅ and Di = resA (Di−1 ∪Ci−1) for all i ∈{1,...,n}. The sequence γ is the context sequence of π , denoted by con(π), and the sequence δ is the result sequence of π , denoted by res(π). Then the sequence τ = W0,W1,...,Wn defined by Wi = Ci ∪Di for all i ∈{0,...,n} is the state sequence of π , denoted by st(π), with W0 = C0 called the initial state of π (and of τ ), denoted by init(π), and Wn called the final state of π (and of τ ), denoted by fst(π). If Ci ⊆ Di for all i ∈{1,...,n}, then we say that π and τ are context-independent. Note that a context-independent state sequence depends only on the initial state (W0 = C0) and its length (n + 1). The set of all state sequences of A (i.e., all state sequences of all interactive processes in A ) is denoted by ST S(A ), and the set of all context-independent state sequences of A is denoted by CIST S(A ). Note that if Wi,Wi+1 are two consecutive states in the state sequence of an interactive process π , then each entity in Wi+1 is either produced by reactions from A enabled on Wi or it is provided by the corresponding context (Ci+1). Hence each entity in Wi+1 is created through the state transitions from Wi to Wi+1. There is no permanency in reaction systems — each entity in a current state is there because it is sustained either by a reaction from A or by the context. This is a major difference with models of concurrent systems in computer science (such as Petri nets — see, e.g., [RE98]), where elements from the current state that are not involved in the local transformations performed by the system on this state just persist (go over to the successor state). Example 2 Let A = (S,A) be a rs with S ={x,y,z1,z2} and A = {({x},{y},{z1}) ({z1},{z2},{x,z2}) ({z2},{z1},{x,y})}. Then the context-independent state sequence τ with the initial state W0 = {x} and length 5 is 3 / 9 Volume 30 (2010) A Note on Causalities in Reaction Systems Figure 1: The influence graph from Example 3. τ = W0,W1,W2,W3,W4 where W1 ={z1}, W2 ={x,z2}, W3 ={x,y,z1}, and W4 ={x,z2}. We will use this A now as the running example of this paper. 4 Resource Dependence and Product Influence There are two basic ways that the entities of a reaction system can influence each other. If a reaction a produces an entity x (i.e., x ∈ Pa), then, for any entity y ∈ Ma, we say that x is resource dependent on y, and that y product-influences x. These dependencies are formally defined as follows. Definition 5 Let A = (S,A) be a rs. • Let x ∈ S. 1. The resource dependence set of x, denoted by MDx, is defined by ⋃ {Ma | a ∈ A,x ∈ Pa}. 2. The product influence set of x, denoted by PIx, is defined by ⋃ {Pa | a ∈ A,x ∈ Ma}. • Let q ∈Z+. 1. A is a rs with q-bounded resource dependence, abbreviated by q-MD rs, if |MDx|≤q for each x ∈ S. 2. A is a rs with q-bounded product influence, abbreviated by q-PI rs, if |PIx|≤ q for each x ∈ S. We introduce now the notion of the influence graph of a rs, which is a very convenient technical tool to investigate resource dependencies and product influences in reaction systems. Definition 6 Let A = (S,A) be a rs. The influence graph of A , denoted by infA , is the digraph (S,E), where for x,y ∈ S, (x,y)∈ E if and only if x ∈ Ma and y ∈ Pa for some a ∈ A. Example 3 The influence graph infA of A of Example 2 is given in Figure 1. Proc. GraMoT 2010 4 / 9 ECEASST The usefulness of the influence graph of A in investigating resource dependencies and product influences in A stems from the fact that these parameters are directly expressible in infA as standard graph-theoretical notions. Thus it is obvious that the following holds. Lemma 1 Let A = (S,A) be a rs. For each x ∈ S, MDx = incinfA (x) and PIx = outinfA (x). Moreover, for q ∈Z+, A is a q-MD rs if and only if idinfA (x)≤ q for all x ∈ S, and A is a q-PI rs if and only if odinfA (x)≤ q for all x ∈ S. Example 4 From the influence graph of A in Figure 1 we find that |PIz1| = |PIz2| = 3, |PIx| = |PIy|= 1, and |MDs|= 2 for all s ∈{x,y,z1,z2}. Hence A is a 3-PI rs and a 2-MD rs. We demonstrate now how to use the influence graph to obtain properties of resource depen- dencies and product influences. Definition 7 Let A = (S,A) be a rs. • The average resource dependence of A , denoted by avMD(A ), is defined as ∑x∈S |MDx| |S| . • The average product influence of A , denoted by avPI(A ), is defined as ∑x∈S |PIx| |S| . Theorem 1 For every rs A , avMD(A ) = avPI(A ). Proof. For every digraph G = (V,E), |E| = ∑x∈V idG(x) = ∑x∈V odG(x), as each edge incoming to some vertex x is outgoing from some vertex y. Hence, by Lemma 1, ∑x∈S |MDx|= ∑x∈S |PIx|, and the theorem holds. Note that, in general: (i) knowing that rs A = (S,A) is a q-MD rs does not yield a bound on max{PIx | x ∈ S}, and symmetrically (ii) knowing that A is a q-PI rs does not yield a bound on max{MDx | x ∈ S}. However, knowing that q bounds the size of resource dependence (product influence, resp.) of A , by Theorem 1 we know that the average product influence (average resource dependence, resp.) of A is also bound by q (because the average does not exceed the maximum). 5 Causal Distances In Section 4 we investigated static causalities in reaction systems, i.e., causalities “directly de- ducible” from the influence graph. In this section we investigate the way that entities influence each other within the dynamics of a reaction system, i.e., within interactive processes. We begin with a useful technical result concerning symmetric differences of states of a rs. Considering symmetric differences allows us to single out the entities by which two states differ (and then to consider consequences of these differences). Lemma 2 Let A = (S,A) be a rs, and let W,W ′ ⊆ S. For each y2 ∈ resA (W )⊕resA (W ′), we have that (y1,y2) is an edge of infA for some y1 ∈W ⊕W ′. 5 / 9 Volume 30 (2010) A Note on Causalities in Reaction Systems Proof. Let y2 ∈ resA (W )⊕resA (W ′). Then there is a reaction a of A with y2 ∈ Pa such that either (1) a is enabled by W and a is not enabled by W ′, or (2) a is enabled by W ′ and a is not enabled by W . Without loss of generality we assume case (1). As a is enabled by W and not enabled by W ′, either Ra ∩(W \W ′) 6= ∅ or Ia ∩(W ′\W ) 6= ∅. Hence there is a y1 ∈ W ⊕W ′ with y1 ∈ Ra ∪Ia = Ma. Consequently, y2 ∈ PIy1 , and therefore (y1,y2) is an edge of infA . The following lemma follows now from Lemma 2 by induction on n. Lemma 3 Let A be a rs. Let τ,τ′∈CIST S(A ) such that τ = W0,W1,...,Wm, τ′ = W ′0,W ′ 1,...,W ′ m for some m ≥ 1, and W0 ⊕W ′0 ={x}. Then, for each n ∈{1,...,m}, if y ∈Wn ⊕W ′ n, then there is a path from x to y in infA of length n. If we consider now q-PI reaction systems, then we obtain a bound on the cardinality of Wn ⊕ W ′n. Lemma 4 Let A be a q-PI rs for some q ≥ 1. Let τ,τ′ ∈ CIST S(A ) be such that τ = W0,W1,...,Wm, τ′ = W ′0,W ′ 1,...,W ′ m for some m ≥ 1, and |W0 ⊕W ′0| = 1. Then, for each n ∈ {1,...,m}, |Wn ⊕W ′n|≤ qn. Proof. By Lemma 3, for each y ∈Wn⊕W ′n, there is a path from x to y of length n. As A is a q-PI rs, by Lemma 1 there are at most qn paths from x of length n, and so the result follows. Example 5 We continue the running example. Recall that A is a 3-PI reaction system. The context-independent state sequence τ′ with the initial state W ′0 = {x,z1} and length 5 is τ ′ = W ′0,W ′ 1,W ′ 2,W ′ 3,W ′ 4 where W ′ 1 = {x,z1,z2}, W ′ 2 = {z1}, W ′ 3 = {x,z2}, and W ′ 4 = {x,y,z1}. If we compare τ′ with the context-independent state sequence τ with the initial state W0 = {x} in Example 2, then W0⊕W ′0 ={z1}, W1⊕W ′ 1 ={x,z2}, W2⊕W ′ 2 ={x,z1,z2}, W3⊕W ′ 3 = W4⊕W ′ 4 = {y,z1,z2}. Hence, the upper bound of Lemma 4 indeed holds for τ and τ′ as |W0 ⊕W ′0| = 1, and |W1 ⊕W ′1|= 2 ≤ 3, |W2 ⊕W ′ 2|= 3 ≤ 9, etc. Definition 8 Let A = (S,A) be a rs, and x,y ∈ S. • Let τ,τ′∈CIST S(A ) where τ = W0,W1,...,Wm, τ′ = W ′0,W ′ 1,...,W ′ m, and W0⊕W ′0 ={x}. Let moreover Zx,y(τ,τ′) ={n ∈{0,...,m} | y ∈Wn ⊕W ′n}. Then the causal distance from x to y in τ , τ′ is defined by: δx,y(τ,τ ′) = { min Zx,y(τ,τ′) Zx,y(τ,τ′) 6= ∅ ω otherwise . • The causal distance from x to y is defined by: cdx,y = min{δx,y(τ,τ′) | τ,τ′ ∈CIST S(A ),|τ|= |τ′|, and init(τ)⊕init(τ′) ={x}}. If the initial states of two state sequences τ and τ′ (of equal length) differ by x only, then by comparing pairwise the corresponding states of τ and τ′ one can reason about the causal influence, within the pair τ,τ′, of x on an entity y. If y “appears” in the symmetric difference Proc. GraMoT 2010 6 / 9 ECEASST of two corresponding states Wn and W ′n, then this appearance is caused by x. If n is the minimal such index (for τ and τ′), then it is the distance of causal influence of x on y within the pair τ,τ′. If on the other hand y never appears in the symmetric difference of two corresponding states of τ and τ′, then x does not influence y within the pair τ,τ′ and so the distance of causal influence of x on y is “infinite” (it is equal to ω ). Obviously, the causal distance between x and y in the total dynamics of A is defined as the minimal distance over all pairs of state sequences τ,τ′ as above. If this distance is n, for some n ∈ Z+, then in some situations (pairs τ,τ′) x can causally influence y over the distance equal n. Example 6 We continue the running example. Recall the context-independent state sequences τ and τ′ from Example 5 with init(τ)⊕init(τ′) ={z1}. We have then (see Example 5): δz1,z1(τ,τ ′) = 0, δz1,x(τ,τ ′) = δz1,z2(τ,τ ′) = 1, and δz1,y(τ,τ ′) = 3. Note that we may thus have “gaps”: there is no v ∈ S with δz1,v(τ,τ ′) = 2, but, we have seen that δz1,y(τ,τ ′) = 3. Also note that cdz1,z2 = 1 as the causal distance between different entities is (by definition) at least 1, and we have δz1,z2(τ,τ ′) = 1. Using Lemma 3, the causal distance from x to y in state sequences τ,τ′ has the following implication in terms of paths in infA . Lemma 5 Let A = (S,A) be a rs and let x ∈ S. Let τ,τ′ ∈CIST S(A ) such that |τ|= |τ′|, and init(τ)⊕init(τ′) ={x}. If δx,y(τ,τ′) = d, then there is a path from x to y in infA of length d. Using Lemma 4, we can now bound the number of entities that have a causal distance d from a given entity x. Theorem 2 Let A = (S,A) be a rs and let x ∈ S. If A is a q-PI rs for q ≥ 1, then for every d ∈Z+, |{y ∈ S | cdx,y = d}|≤ qd . As a corollary we prove that if, for a q-PI rs A = (S,A), there is a common (finite) bound on causal distances from x to y for all x,y ∈ S, then this common bound can be used to bound |S|. Corollary 1 Let A = (S,A) be a q-PI rs for some q ≥ 1. Let x ∈ S, and let n0 ≥ 0 be such that cdx,y ≤ n0 for all y ∈ S. Then |S|≤ ∑ n0 d=0 q d . Proof. Let x ∈ S. Then by Lemma 5, for every d ∈ Z+, |{y ∈ S | cdx,y = d}| ≤ qd . Hence |{y ∈ S | cdx,y ≤ n0}|≤ ∑ n0 d=0 q d . Since cdx,y ≤ n0 for all y ∈ S, |S| = |{y ∈ S | cdx,y ≤ n0}|, and so |S|≤ ∑n0d=0 q d . We note here that the causalities we investigate are between entities of a reaction system. This is quite different from the traditional research on causalities in models of concurrent systems (see, e.g., [RE98]), where the causal dependencies hold between events (actions of a system). We can do this, because (as pointed out in Section 3) each entity in a current state is created in the transition from the previous state. Hence our causal dependencies between entities x and y can be also seen as causal dependencies between the actions of creating x and y. 7 / 9 Volume 30 (2010) A Note on Causalities in Reaction Systems 6 Predictability Let A = (S,A) be a rs. Assume that we are interested in a specific x ∈ S, and we would like to know (to be able to predict) whether or not, for a specific n ∈ Z+, x will be present in the final state of a n-step process π . Since π is uniquely determined by con(π) (and A), knowing con(π) allows us to answer this query. However, since we are interested in a specific x and a specific n, perhaps to answer this query it suffices to know only a part of (each set of) con(π). More specifically, perhaps (for given x and n) there is a subset Q ⊆ S which is the key to answering this query, meaning that if, for any two n-step interactive processes, the Q-projections of the context sequences of these processes are equal, then either x is in both final states (of these processes) or in none of them. Then Q is a subset of S which is a cause for x to be uniformly either present or absent in the final state of any n-step interactive process. Such predicting subsets of S are investigated in this section. Definition 9 Let A = (S,A) be a rs. For x ∈ S, n ≥ 1, and Q ⊆ S, we say that Q n-predicts x, if for arbitrary n-step interactive processes π1 and π2 the following holds: if projQ(con(π1)) = projQ(con(π2)), then x ∈ fst(π1) if and only if x ∈ fst(π2). Note that for all x ∈ S and all n ≥ 1, S n-predicts x. Let, for x ∈ S and n ≥ 1, Px,n ={Q ⊆ S | Q n-predicts x}. Since S ∈ Px,n, Px,n is nonempty, and so it contains minimal elements (w.r.t. inclusion). Theorem 3 Let A = (S,A) be a rs, x ∈ S and n ≥ 1. Then Px,n contains exactly one minimal element. Proof. Assume to the contrary that Px,n contains two different minimal sets Q1 and Q2. Let Z = Q1 ∩Q2. As Z is strictly included in Q1 (and Q2), and Q1 and Q2 are minimal, Z does not n-predict x. Let thus π′ and π′′ be arbitrary n-step interactive processes such that projZ(γ ′) = projZ(γ ′′) with γ′ = con(π′), γ′′ = con(π′′), and x ∈ fst(π′), while x 6∈ fst(π′′). Let γ′ = C′0,...,C ′ n and γ ′′ = C′′0 ,...,C ′′ n . Consider now the S-sequence γ = C0,...,Cn, where Ci = (Q1 ∩C′i)∪(Q2 ∩C ′′ i ) for i ∈{0,...,n}. We have Q1∩Ci = (Q1∩C′i)∪(Q1∩Q2∩C ′′ i ). Also, we have Q1∩Q2∩C ′′ i = Z∩C ′′ i . Moreover, Z∩C′′i = Z∩C ′ i , because projZ(γ ′′) = projZ(γ ′). Since also Z ⊆ Q1, we obtain Q1∩Ci = Q1∩C′i . Consequently, projQ1(γ) = projQ1(γ ′). Analogously one proves that projQ2(γ) = projQ2(γ ′′). Let π be the interactive process corresponding to γ . Since Q1 n-predicts x and x ∈ fst(π′), we have x ∈ fst(π). Similarly, since Q2 n-predicts x and x 6∈ fst(π′′), x 6∈ fst(π) — a contradiction. Therefore Px,n contains exactly one minimal element. We denote the (unique) minimal element of Px,n for x ∈ S and n ≥ 1, by prdA (x,n), and refer to it as the n-predictor of x (in A ). Note that in a context-independent n-step interactive process π = (γ,δ ), as far as the state sequence st(π) is concerned, we can assume that γ = C0,...,Cn is such that C1 = ∅,...,Cn = ∅ (because all the contributions of C1,...,Cn to st(π) are already included in D1,...,Dn where δ = D0,...,Dn). Therefore, if, for x ∈ S, we want to know whether or not x appears in the final Proc. GraMoT 2010 8 / 9 ECEASST state of an arbitrary context-independent n-step interactive process π , it suffices to know which entities of prdA (x,n) are included in the initial state of π — all other entities of the initial state are irrelevant as far as this query is concerned! Our next result bounds the size of n-predictors. Theorem 4 Let A = (S,A) be a q-MD rs for q≥1. For each x∈S and each n≥1, |prdA (x,n)|≤ ∑ n k=0 q k. Proof. Each y∈prdA (x,n) product-influences x in at most n steps. By the definition of influence graph, for each entity y that product-influences x in k-step (for some k), there is a path of length k from y to x. Since A is a q-MD rs, by Lemma 1 there are at most ∑nk=0 q k paths to x in infA of length at most n. Therefore |prdA (x,n)|≤ ∑ n k=0 q k. Example 7 Recall that A in the running example is a 2-MD rs (see Example 4). Hence we have, e.g., |prdA (z1,1)|≤ 3. Acknowledgements The authors are indebted to Mike Main and the anonymous referees for useful comments. Bibliography [EMR10] A. Ehrenfeucht, M. G. Main, G. Rozenberg. Combinatorics of Life and Death for Reaction Systems. International Journal of Foundations of Computer Science 21(3):345–356, 2010. doi:10.1142/S0129054110007295 [ER07a] A. Ehrenfeucht, G. Rozenberg. Events and modules in reaction systems. Theoretical Computer Science 376(1-2):3–16, 2007. doi:10.1016/j.tcs.2007.01.008 [ER07b] A. Ehrenfeucht, G. Rozenberg. Reaction Systems. Fundamenta Informaticae 75(1- 4):263–280, 2007. [ER09] A. Ehrenfeucht, G. Rozenberg. Introducing time in reaction systems. Theoretical Computer Science 410(4-5):310–322, 2009. doi:10.1016/j.tcs.2008.09.043 [RE98] G. Rozenberg, J. Engelfriet. Elementary Net Systems. In Reisig and Rozenberg (eds.), Lectures on Petri Nets I: Basic Models. Lecture Notes in Computer Science 1491, pp. 12–121. Springer, 1998. doi:10.1007/3-540-65306-6 14 9 / 9 Volume 30 (2010) http://dx.doi.org/10.1142/S0129054110007295 http://dx.doi.org/10.1016/j.tcs.2007.01.008 http://dx.doi.org/10.1016/j.tcs.2008.09.043 http://dx.doi.org/10.1007/3-540-65306-6_14 Introduction Preliminaries Reactions and Reaction Systems Resource Dependence and Product Influence Causal Distances Predictability