 
 
 
 
 
 
 
  
The most important aspect of a cellular automaton is the transition rule or transition function. This is what determines the evolution most. Of course the transition rule depends on the lattice geometry, the neighborhood, and the state set. Even though the transition rule most directly determines the evolution, it is in many cases not possible to predict the evolution of a CA other than by explicitly simulating it (One can prove that this is the case for those automata that can be shown to be computationally universal, such as simple automata like the ``game of life'').
![[*]](cross_ref_motif.gif) ), page
), page
![[*]](cross_ref_motif.gif) , this would be
This list is very long and tedious to write down. In many cases, as in the 
example, 
the specification can be greatly simplified by the introduction of 
wild-cards, i.e.,
by indicating cases where the transition result is independent of the 
content of 
(usually) a neighbor cell. 
Indicating a wild-card by ``
, this would be
This list is very long and tedious to write down. In many cases, as in the 
example, 
the specification can be greatly simplified by the introduction of 
wild-cards, i.e.,
by indicating cases where the transition result is independent of the 
content of 
(usually) a neighbor cell. 
Indicating a wild-card by ``![$\makebox[0.5em]{$\scriptstyle\bullet$}$](img48.gif) '', we write the same rule as 
Eq. (2.10) 
in the shorter form 
When specifying a transition rule in this manner, one has to 
take care that the specification does indeed allow a consistent and full 
construction of the complete table. It is this requirement that lead to the 
specification in Eq. (2.11) being still more 
complicated than the specification in Eq. (
'', we write the same rule as 
Eq. (2.10) 
in the shorter form 
When specifying a transition rule in this manner, one has to 
take care that the specification does indeed allow a consistent and full 
construction of the complete table. It is this requirement that lead to the 
specification in Eq. (2.11) being still more 
complicated than the specification in Eq. (![[*]](cross_ref_motif.gif) ), 
which was intuitively clear. If we extend the definition of wild cards in 
such a manner that the first applicable rule takes precedence over 
following rules, we can simplify Eq. (2.11) to 
We see that by introducing this precedence rule, we have eliminated the 
three rules that were listed in the second column of Eq. (2.11).
), 
which was intuitively clear. If we extend the definition of wild cards in 
such a manner that the first applicable rule takes precedence over 
following rules, we can simplify Eq. (2.11) to 
We see that by introducing this precedence rule, we have eliminated the 
three rules that were listed in the second column of Eq. (2.11).
Further simplification can often be achieved by grouping states together according to the symmetries of the lattice. For the one-dimensional version with rules symmetric under reflection, we can write
and thus obtain the same number of cases as in Eq. (![[*]](cross_ref_motif.gif) ).
In two dimensions the implicit specification of symmetric cases is even 
more important. The two-dimensional rules would be
).
In two dimensions the implicit specification of symmetric cases is even 
more important. The two-dimensional rules would be
![\begin{equation}
\begin{array}{l@{\qquad}l}
\begin{array}{ccc}&2&\\ \makebox[0.5...
...5em]{$\scriptstyle\bullet$}&\end{array} \rightarrow 0
\end{array}\end{equation}](img52.gif) 
 .
Thus we have reduced the description to the essential parts.
.
Thus we have reduced the description to the essential parts. 
This type of description is used in the ``GUI''-Approach to specifying rules in the JCASim system. Other descriptions use special languages, such as CDL or Java for specifications (see Chapter 3).
![[*]](cross_ref_motif.gif) and
 and ![[*]](cross_ref_motif.gif) ). For our example automaton, we 
demonstrate this in another version of 
the two-variable rule Eq. (
). For our example automaton, we 
demonstrate this in another version of 
the two-variable rule Eq. (![[*]](cross_ref_motif.gif) ), where we 
include diffusion effects in variable
), where we 
include diffusion effects in variable  :
Step 1 calculates the sum in the neighborhood of variables
:
Step 1 calculates the sum in the neighborhood of variables  and
 and  separately:
separately:
 In principle, the neighborhoods for calculating
In principle, the neighborhoods for calculating  and
 and  can be different
(for more details see Chapter
 can be different
(for more details see Chapter ![[*]](cross_ref_motif.gif) ).
Step 2 calculates the new value of
).
Step 2 calculates the new value of  from
 from  ,
,  and
 and  , 
with
, 
with  being the number of cells in the
neighborhood for
 being the number of cells in the
neighborhood for  (which includes the cell to be updated):
 (which includes the cell to be updated):
 and step 3 calculates the new value of
and step 3 calculates the new value of  :
:
![\begin{mathletters}
\begin{eqnarray}
(u_{\rm new}=0, \tilde v) &\rightarrow& v_{...
...left[{\tilde v + n\, v_+ \over n}\right]\right\}
\end{eqnarray}\end{mathletters}](img57.gif) Of course we could write down the combined effect of steps 1 through 3 
in one explicit step, but it is often more convenient to use this stepwise 
formulation, even if the actual simulation uses fewer separate steps.
Of course we could write down the combined effect of steps 1 through 3 
in one explicit step, but it is often more convenient to use this stepwise 
formulation, even if the actual simulation uses fewer separate steps.
In JCASim such multistep rules use global vaiables which control the stepping.
![\begin{equation}
G: S^n \times S \rightarrow [0,1],
\end{equation}](img58.gif) 
 
 is nonzero for only a few values of
 is nonzero for only a few values of  .
.
The introduction of probabilistic rules is very important in many modeling situations, since many natural systems are noisy. In some cases it is sufficient to introduce random initial conditions, which also lead to a noisy or random behavior. But in many cases probabilistic rules have advantages.
 
 Applet 2.17: Probabilistic rules with  . Evolution from an initial point,
showing every second time step.
. Evolution from an initial point,
showing every second time step.
Let us demonstrate the effects of introducing probabilistic rules in 
our example. We use the following rule with  (
 ( is the probability):
 is the probability):
 The effect of the probabilistic rules is that wavefronts do not 
remain flat, and do not propagate at full speed, since infection does not 
always take place. Figure 2.17 
shows the evolution of an initial small excited region. We observe that the 
wave front is irregular, but more circular than with deterministic rules (A
detailed investigation into different ways to achieve good isotropy in 
cellular automata can be found in [5]). 
We also observe (in the second row) that the wave front has broken up, 
and propagates back into the interior.
We have selected the version with
The effect of the probabilistic rules is that wavefronts do not 
remain flat, and do not propagate at full speed, since infection does not 
always take place. Figure 2.17 
shows the evolution of an initial small excited region. We observe that the 
wave front is irregular, but more circular than with deterministic rules (A
detailed investigation into different ways to achieve good isotropy in 
cellular automata can be found in [5]). 
We also observe (in the second row) that the wave front has broken up, 
and propagates back into the interior.
We have selected the version with  because for
 because for  this phenomenon 
happens very often, and is less easy to recognize.
 this phenomenon 
happens very often, and is less easy to recognize.
We will encounter several examples of cellular automata with probabilistic rules in the later chapters, and also discuss how to simulate a probabilistic automaton into a deterministic automaton by integrating a random number generator in the CA rules.
 
 
 
 
 
 
