Universality of the chip-firing game  by Goles, Eric & Margenstern, Maurice
ELSEVIER Theoretical Computer Science 172 ( 1997) 12 l-l 34 
Theoretical 
Computer Science 
Universality of the chip-firing game 
Eric Gales a, *, Maurice Margenstern b 
a Departamento Ingenieria Matemcitica, Universidad de Chile, Casilla 170-3, Santiago, Chile 
b Universite de Metz, I. U. T. de Metz, and LITPIIBP (Paris), Ile du Saulcy. 
57045 Metz Gdex I, France 
Communicated by August 1995; revised November 1995 
Communicated by M. Nivat 
Abstract 
We prove that the parallel updating of the chip-firing game on undirected graphs is univer- 
sal. To achieve that, we simulate any given two-register machine by chip configurations. As 
corollaries, we prove that for finite graphs there exists exponential transient ime to reach peri- 
odic configurations as well as exponential cycles. Also, we prove, for infinite graphs, that the 
reachability problem is undecidable. 
1. Introduction 
Let G = (V, E) denote an undirected graph, each vertex being finitely many con- 
nected, but G being possibly infinite. A distribution of chips is set on the set of vertices 
of G, say x; chips, xi 3 0, in vertex i. The local rule of the game is the following: if 
the number of chips, Xi, is not less than the degree di of vertex i, the vertex gives one 
chip to each of its neighbors. T’he game can be played asynchronously, (i.e. vertices 
with enough chips are updated one by one) or in parallel. The last iteration mode can 
be defined as follows: 
xi(t + 1) = xi(t) - dil(xi(t) - di) + C I(~i(t) - dj), 
jGV, 
where x(O) E NIV1 is the initial distribution of chips and l(u) = 1 iff u 2 0, 0 otherwise. 
Fig. 1 gives an example of the parallel dynamics of a finite graph: 
It is important to point out that, for finite graphs, the parallel iteration on a con- 
figuration x(t), can be simulated by the sequential update of the 1 V 1 vertices one by 
one in order 1,2 ,..., [VI. It is clear that after updating every vertex which has enough 
chips, configuration x(t + 1) reached by parallel updating x(l) is also obtained. 
* Corresponding author. E-mail: egoles@dim.uchile.cl. 
0304-3975/97/$17.00 @ 1997 -Elsevier Science B.V. All rights reserved 
PII SO304-3975(95)00242-l 
122 E. Gales, M. Margensternl Theoretical Computer Science 172 (1997) 121-134 
Fig. 1. Cycle of period four of the chip-firing game. 
The chip-firing game has independently been introduced in discrete mathematics and 
statistical physics and is related to many problems. In discrete mathematics it was 
introduced by Spencer [ 171 to analyze a balancing game. In physics it was introduced 
by Bak et al. [2] in order to model sand pile avalanches in the framework of the self 
organized criticallity paradigm. Next is a brief survey of the main results and studies 
about this model. 
Anderson et al. [l] studied the number of steps in function of the initial number 
of chips placed in one site of Z, which the game needs to converge to a quiescent 
configuration (i.e. each site has at most one chip). Later those studies were extended 
to general graphs by Bjiimer et al. [5]. Tardos [18] showed that if the chip-firing game 
over an undirected graph terminates, then it terminates in a polynomial number of 
steps, depending on the number of vertices. Eriksson [6] showed that when the graph 
is directed, then terminating the game can be exponentially long. 
From the physical point of view, the chip-firing game can be seen as a sand- 
pile model, as it is pointed out in [9, lo]. The sand-pile model consists of a lo- 
cal rule to produce avalanches in a one-dimensional non-increasing configuration of 
sand-grains [2]. When a local slope is greater than a critical threshold, a grain of 
sand tumbles to the next right pile. In [ 10, 1 l] the equivalence has been studied be- 
tween this model and the one-dimensional chip-firing game proposed in [l]. Further- 
more, the sand-pile point of view allows to give exact expressions, depending on the 
number of initial chips, on the number of steps needed to reach a quiescent confi- 
guration [ 111. 
Most previous models are related with the asynchronous update; i.e. one fires vertices 
one by one in an arbitrary order. The parallel chip firing game has been studied in [3], 
where an invariant property is shown about the activity of vertices (i.e. the temporal 
pattern of firing and no firing situations). From this property, it was also proved that 
the parallel chip firing game converges towards periods of length at most 2 when the 
graph is a finite tree. 
Prisner [ 151 studied properties of the parallel chip-firing game on directed graphs and 
he proved that for every strongly connected eulerian multidigraph there is a parallel 
chip-firing game that evolves into steady states with period equal to the length of the 
longest dicycle in the underlying graph. It was also conjectured that this was the longest 
possible period reached by the parallel chip-firing game on such digraphs. Later, this 
E. Gales, hf. MargensternITheoretical Computer Science 172 (1997) 121-134 123 
conjecture was disproved in [ 131 by exhibiting chip-firing games on a planar connected 
undirected graph which admits nonpolynomial periodic configurations on the number 
of vertices. 
In addition, some comments and examples were supplied in [9] in order to show 
that the parallel chip-firing game has a complex dynamical behavior. In fact, with 
small configurations, called gliders, some particular algorithms were coded in chip 
configurations. 
The main result of our paper reads as follows. 
Theorem 1. There is a universal parallel chip-jring game on an infinite, connected 
undirected graph. 
Proof is made by simulating an arbitrary two register-machine on a chip-firing game. 
To carry out our construction, we first simulate bits 0 and 1 as well as logical gates 
OR, AND and negation by particular configurations of chips. 
Various corollaries of those simulations are derived or proved, namely: 
- the construction of exponential transients and cycles on chip-firing games in finite 
graphs, 
_ the existence of universal games on a graph with maximum degree three, 
_ the undecidability of the reachability problem. 
2. Logical gates 
First, let us remark that in a graph of degree 2 (i.e. each vertex has precisely two 
neighbors), the configuration with 0 chips in vertex k, 2 chips in vertex k + 1 and 
a single chip everywhere else, is a glider shifting to the right. Symmetrically, with 2 
chips in vertex k and 0 chips in vertex k + 1, a glider to the left is obtained: 
1 l...l 0 2 1 l... 
1 l... 1 12 0 l... 
And so 0 2 in a background of l’s breaks the symmetry of the graph and allows 
us to convey information. 
It is also possible to duplicate such information by putting bifurcations as follows: 
where d, is the degree of vertex x. 
124 E. Gales. A4. MargensternITheoretical Computer Science I72 (1997) 121-134 
We will develop this point in Section 3. 
The existence of gliders suggests that information bits 1 and 0 should be encoded 
as follows: 
+0-G& -(5-s-& 
i-o-0+4- Fa-o-eu- 
0 2 1 1 1 1 0 2 
x=1 x=0 
That is to say, bit 1 is coded by A i y : and bit 0 by i i A :. We have chosen 
this encoding to model the necessary notions of input and output in logical systems 
as well as to model negation. Starting from that, logical gates may be simulated as 
follows: 
Lemma 1. The logical NOT, OR and AND gates are, respectively, given by the 
following subgraphs: 
NOT-GATE: 
x 
x x x 
x X 
OR-GATE: 
X 
X 
x XVY 
YY 
XVY 
L 
AND-GATE: 
x x 
si XAY 
- 
Y XAY 
Y 
L 
E. Gales, M. Margensternl Theoretical Cmputer Science 172 (1997) 121-134 125 
Proof. The reader can easily check that after 6 steps of computation, the following 
configurations, with obvious notations, are true: 
Let 1 denote signal 1102, let 0 denote signal 02 11 and let n denote the neutral signal 
1111. Hence the following rules, in obvious notations: 
I,0 2 n 
0,o 2 n 
1,o 
IfI 
1 It 
1,l 1 n 
n,n 2 1 
W 2 0 
n,n 1 0 
n,n 
Fl 
1 1 
It can be easily checked that Q and (J) behave, respectively, like OR and AND 
operators on partial signals 1 and 2. As a V b = ii A 6 and a A b = i!i V 5, Lemma 1 is 
proved. 0 
3. The machine structure 
As known from Minsky [ 141, any Turing machine can be simulated by a two register- 
machine. Simulating register architecture will now be dealt with. As an integer stored 
in a register may have an arbitrary size, our registers must have an infinite structure. 
126 E. Gales, M. Margenstern I Theoretical Computer Science I72 (1997) 121-134 
To model a register machine, it suffices to build two registers together with a program 
controller. Therefore, we first need to define two new subgraph structures, which will 
be performed in Section 3.1. We shall use computer architecture conventions namely 
those of PLA (Programmable Logical Array), for designing subgraphs devoted to 
logical tasks. Other ways can be used for that purpose, but our intention is to stress 
the connection with architectural features. 
3.1. Preliminary subgraphs 
Recall that configuration (1 ), below, allows us to duplicate any signal 0 or 1: 
0 
4 1 1 2 0 
(2) 
By cascading, such a duplication can be extended to any power of 2 in a balanced 
way, using a suitable binary tree d, inducing the same delay in conveying for every 
replicate of the signal. This can be extended to any number n > 2, provided branches 
could be freely “killed” in tree d, only using a finite sub-graph. The simple mechanism 
as illustrated in (2), above, provides a way of absorbing any signal 1102 or 0211. 
So a l-wire signal can be replicated n times with the same delay. This can obviously 
be extended to a 2-wire signal. 
3.2. Registers 
We define each register in our simulating graph as cells set on a half-line. Each cell 
is a subgraph defined as follows. 
The register uses four global signals, say a,~, r and d, each one using a wire for 
conveying information. Each cell has a local wire, denoted m, which stores signal 
1 or 0 as memory unit. Recall that signal 1 means configuration i k y t on “parallel” 
branches of the graph and that signal 0 means configuration y : i i, 
Numbers are written in unary notation. For example, 4 is stored as 
1 1 1 1 o...o... 
and the empty register is stored as 
0 0 0 0 o...o... 
E. Gales, M. Margensternl Theoretical Computer Science 172 (1997) 121-134 127 
Table 1 
Case d = 0: 
a=0 
a=1 
Case d = 1: 
a=0 
s=o 
d’ = 0 
r’ = 0 
m=l i-l = 0 
d’ = 0 
m=O I?? = 1 
r’ = 1 
d’ = 0 
a’ = 0 
s=l 
m=l r’ = 0 
d’ = 0 
m=O r’ = 1 
d’ = 1 
s’ = 0 
not used 
Signals a and s tell the register which operation to perform as well as they order it 
to remain in waiting state. Signals r and d give an account of how the operation was 
performed. 
The structure of a register cell is illustrated below: 
a 
S 
r’ 
d’ 
- a’ 
-_s’ 
_r 
-d 
arrows indicate the direction 
entailed by the glider moving 
on the wire 
Let a, s, m, r and d denote the input signals entering the cell and let a’, s’, m’, Y’ and d’ 
be the corresponding outputs. The correspondence between outputs and inputs is given 
by Table 1. 
In order to make the tables more readable, it is assumed that not explicitly affected 
signals, say cr, obey the rule 6’ = cr. In the second table, case a = 1 does not occur. 
As an illustration, Figs. 2-5 below give the representation of a cell register in terms 
of PLA (Fig. 2) as well as in terms of graphs (Figs. 3-5). 
Intuitively, instructions of the form add 1 to the content of the register are performed 
by sending a signal a = 1, s = 0, which “calls” each cell, passing over those which 
128 E. Gales, M. Margensternl Theoretical Computer Science 172 (1997) 121-134 
d&ass mm mmaassddrr 
I I I I I I I I I I I I I I I I II 
Fig. 2. 
r. 0 
l-0 0 
Fig. 3. 
contain signal 1 and stopping on the first occurrence of signal 0 which is changed into 
signal 1. The operation is completed and so signal or = 1 is sent back to the program 
controller. For instructions of the form subtract 1 from the content if it is positive, 
the signal is a = 0 and s = 1. The same calling occurs and it also stops on the first 0 
encountered. But this time signal m is unchanged and signal d = 1 is sent back to 
E. Gales, M. Margemternl Theoretical Computer Science I72 (1997) 121-134 
-a- 
x-b 
Fig. 4 
129 
Fig. 5. 
130 E. Gales, M. Margenstern I Theoretical Computer Science 172 (1997) 121-134 
reach the “left” neighbor of the cell. It then changes occurring 1 into 0, except if the 
cell which sent signal d = 1 is the first cell of the register. In that latter case, signal 
d = 1 is received by the program controller (in the other cases it always receives 
d = 0), which means that the content of the register was equal to 0 and, as a result, 
decrementing it was not possible. 
The corresponding subgraph is represented above in Figs. 3 and below in Fig. 4, 
which have to be joined as shown below in Fig. 5. 
Before turning to the program controller, it must be mentioned that the length of the 
path joining output m’ to input m allows us to synchronize the first significant part of 
signal m with the corresponding parts of the other inputs. 
3.3. Program controller 
As the program controller basically behaves like a finite automaton and as its struc- 
ture, described in [12] thoroughly, cannot be contained in this paper, we illustrate its 
general working on the simple finite automaton A defined in Fig. 6. The representation 
of the corresponding jinite graph is given in PLA form in Fig. 7. 
1 
0 1 
v 
O O1 
2 
I 0 I 1 
f--k-t+ 
I I 
2 2 1 
Fig. 6. 
Fig. 7. 
E. Gales, M. Margenstern I Theoretical Computer Science 172 (1997) 121-134 131 
It should be noticed, in these figures, that an input wire is assigned to each state 
and to each letter of automaton A. Then, the automaton transition table is translated 
by the column of AND’s in Fig. 7. The output wire of each end transmits the “firing” 
signal to the output state of the automaton transition table. Output wires “go back” to 
the former part of the graph as input wire conveying the automaton new input state, 
since only one of these wires conveys a 1 signal. Notice that input wires corresponding 
to the letter read by automaton A at the current time are supposed to be fed by an 
appropriate device. 
The program controller typically works the same way. The role of the automaton in- 
put letters is played by signals corresponding to which degree of completion is reached 
while performing the simulated instruction. An illustrative example is provided in [12]. 
To ensure completeness of presentation, it must be indicated how to initialize the 
graph. In fact, signal 0 is put at every place corresponding to a top of synchronization, 
except in two places: entry of wire r into the program controller with signal 1 and 
entry of wire for instruction 0 also with signal 1; all other vertices are fitted with a 
single chip. This involves infinitely many chips at initial time. 
4. The chipfiring game calculator 
Clearly, Theorem 1 follows from Section 3.3. Besides, since the maximum number of 
chips on a vertex and duplication of signal and multiple entries for AND and OR gates 
can be carried out by cascading corresponding binary operations (see Section 3.1), one 
may construct a universal game with maximum degree 3 in each node. This can be 
summarized as follows: 
Corollary 1. There is a universal parallel chip-jring game on an infinite connected 
undirected graph such that the degree of any vertex is not greater than 3 and such 
that, at any time, the greatest number of chips to be found in any vertex is at most 4. 
Corollary 2. Given any finite automaton with states d and symbols C, one can simu- 
late it on a finite graph, whose number of vertices is bounded by a quadratic function 
of IdI and IzI. 
Proof. This directly follows from the construction of our program controller. 
Corollary 3. The parallel chip-firing game on finite graphs admits exponential cycles. 
Proof. The length of cycles and transitions of boolean functions which are linear over 
Z/Z2 have thoroughly been studied, see for instance [8]. Exponential cycles can be 
observed for the following transform: 
yi=xi_t XOR xi+1 for 1 <i<n, 
yl =x,, XOR x2 and y, = x,-t XOR XI. 
132 E. Gales, M. Margenstern I Theoretical Computer Science 172 (1997) 121-134 
Fig. 8. 
Fig. 9. 
Fig. 8 illustrates this case for n = 3 in PLA convention whereas Fig. 9 does the 
same for n = 5, directly in graph representation. 
In Fig. 8, notice that after passing through the OR-gates, wires are duplicated into 
pairs of conjugate wires in terms of signals 0 and 1. This is more easily performed 
in Fig. 9. 
These figures clearly show that the constant contained in O(n) is a small one since 
about 40 vertices are used for each pair of XORs the number of which is n. 
E. Gales, h4. Margenstern I Theoretical Computer Science 172 (‘1997) X21-134 133 
Notice that those results improve what was proved in [13], namely that there are 
nonpolynomial cycles for parallel chip-firing games on finite graphs. 
Moreover, as regards parallel updating, very slow convergence towards periodic con- 
figurations can be obtained. 
Corollary 4. The parallel chip-jiring game may take exponential time (in the number 
of vertices) to reach a periodic configuration. 
Proof. It suffices as in Corollary 3 to notice that there exist XOR-matrices with dimen- 
sion n such that, starting from a boolean state x(O), configuration (1,. . , 1) is reached 
after 2” - 1 parallel steps, simulating the same number of iterations. Whence the result 
follows, since such matrices can be simulated by chips configurations. 
The universality of parallel firing chip games clearly entails that this model admits 
undecidable problems. One of them is the reachability problem: given two configura- 
tions c and c’ on the chip firing game, decide whether or not cf can be reached from c 
by the application of the chip rule. 
A decidable situation of that problem was studied in a related game in [7]. For finite 
graphs the reachability problem is clearly decidable because starting from a finite initial 
number of chips, the number of configuration is finite. An efficient algorithm is given 
in [4]. Now, in our case, we have the following result. 
Corollary 5. The reachability problem is undecidable on infinite, connected, undi- 
rected graphs. 
Proof. It is well known that a two register machine may simulate a universal Turing 
machine [14]. Consequently, the problem to know whether starting from particular 
values rl,rz in its registers the machine reaches values ri, r; and halts can be reduced 
to the following problem of recursivity theory: is the set {x, y, e; cp,(x) defined and 
cp,(x) = y} recursive? An easy application of Rice theorem (see [ 161) shows that it is 
not. The corollary directly follows from Theorem 1. 
5. Conclusions 
As we have pointed out in the introduction, parallel updating for finite graphs can 
be simulated by sequentially updating vertices of the current configuration in order 
1,2, . . . ,I VI. It directly follows from this that, for this particular asynchronous dynamics 
(cyclically updating vertices in order 1,. . . , n) Corollaries 2-4 also hold. 
Drawing on previous studies, with finitely many chips on an infinite graph, the 
parallel chip-firing game remains decidable. It is important to notice that in order to 
convey gliders we need to put at least one chip in infinitely many vertices in the initial 
configuration. Consequently, our hypotheses are necessary to obtain an undecidability 
result. Our present work shows that they are also sufficient. 
134 E. Gales, M. Margenstern I Theoretical Computer Science I72 (1997) 121-134 
It remains open whether the universality property of the game can be proved for 
planar graphs, since our construction is based upon the simulation of negation by 
crossing wires. 
Acknowledgements 
This work was partially supported by ECOS (E.G., M.M.), E.C. project in Ap- 
plied Mathematics (E.G.) and FONDECYT # 1940520 (E.G.), the Laboratoire de 
Mathtmatique d’Orsay from University Paris 11. 
References 
[1] R.J. Anderson, L. Lovasz, P. Shor, J. Spencer, E. Tardos and S. Winograd, Disk balls and walls: 
analysis of a combinatorial game, Amer. Math. Monthly 96 (1989) 481-493. 
[2] P. Back, Ch. Tang and K. Wiesenfeld, Self organized critically: an explanation of l/f noise, Phys. 
Rev. Lett. 59 (1987) 381-384. 
[3] J. Bitar and E. Goles, Parallel chip-tiring game on graphs, Theor. Comput. Sci. 92 (1992) 291-300. 
[4] A. Bjijmer and L. Lovasz, Chip firing games on directed graphs, J. Alg. Combin, 1 (1992) 305-328. 
[5] A. Bjiimer, L. Lovasz and P. Shor, Chip firing games on graphs, Eur. .I. Combin. 12 (1991) 283-291. 
[6] K. Eriksson, No polynomial bound for the chip-firing game on directed graphs, Proc. Amer. Math. 
Sot. 112 (1991) 1203-1205. 
[7] K. Eriksson, Reachability is decidable in the numbers game, Theor. Comput. Sci. 131 (1994) 431-439. 
[8] A. Gill, Linear Sequential Circuits, Analysis, Sintesis and Applications, McGraw Hill Series in 
Systems Sciences ( 1966). 
[9] E. Goles, Sand piles, combinatorial games and cellular automata, in: Tirapegui et al. eds., Proc. 
Instabilities and nonequilibrium structures-III (Kluwer, Dordrecht, 1991). 
[lo] E. Goles, Sand pile automata, Ann. Inst. H. Poincare, Phys. Theor 56 (1992) 75-90. 
[I I] E. Goles and M. Kiwi, Games on line graphs sand piles, Theor. Comput. Sci. 115 (1993) 321-349. 
[ 121 E. Goles and M. Margenstem, Universality of the parallel chip-firing game and related results, Research 
Report LITP 95133, 1995. 
[13] M. Kiwi, R. Ndoundam, M. Tchuente and E. Goles, No polynomial bound for the period of the parallel 
chip-firing game on graphs, Theor. Comput. Sci. 136 (1994) 527-532. 
[ 141 L.M. Minsky, Computation: fmite and Infinite Machines (Prentice-Hall, Englewood Cliffs, NJ, 1967). 
[15] E. Prisner, Parallel chip-firing games on digraphs. Tech. Report Mathematisches Seminar, Universitiit 
Hamburg, Nov. 1994, Complex Systems, to appear. 
[16] H. Rogers, Theory of Recursive Functions and Effective Computability (McGraw-Hill, New York, 
1967). 
[17] J. Spencer, Balancing vectors in the max norm, Combinatorics 6 (1986) 55-66. 
[18] G. Tardos, Polynomial bound for a chip-firing game on graphs, SIAM .I. Discrete Math. 1 (1988) 
397-398. 
