User:Iztok.jeras/Sandbox
From Wikipedia, the free encyclopedia
Contents |
[edit] Mathematical model
Formally, a cellular automaton is represented by the 5-tuple where:
- Z is the finite or infinite lattice
- S is a finite set of cell states or values
- N is the finite neighborhood
- f is the local transition function defined by the transition table or the rule
- B description of the cell space boundary, used only if there are boundaries to be defined
The lattice is a finite or infinite discrete regular grid of finite number of dimensions, filled with cells. Each cell is defined by it's discrete position (an integer number) and by it's discrete value (a finite set of integers). Time is also discrete. The future state of a cell at time t + 1 is a function of the present state of a finite number of cells called the neighborhood at time t − 1.
[edit] One dimensional first order cellular automata
For the sake of readability the next definitions focus on one dimensional first order cellular automata.
[edit] Lattice, cell and configuraton
The global state is a configuration C in SZ. S is the finite set of cell states, for formalization purposes the states are enumetated . Z is the lattice, the infinite cyclic group of integers {..., − 1,0,1,2,...}.
[edit] Neighborhood, local transition function and rule
The cells in the neighborhood ni of the cell ci have indexes i + j, where are values from the set of neihbours N.
A compact representation of the neighborhood value ni is a single integer defined as a number of k digits base | S | .
The local transition function
calculates the value of a single future cell ci from the neighborhood of the observed cell in the present.
The transition table defines the local transition function by listing the output value for each input value.
x -> f(x) ----------- 000 -> 0 001 -> 0 ........ 111 -> 0
The rule r is a compact representation of the local transition function. It is a single integer defined as a number of k digits base | S | .
[edit] Global transition function
The global dynamics of CA are described by the global transition function
F translates the current (present) configuration Ct into the next (future) configuration Ct + 1
The global transition function F is defined by the local transition function f as
[edit] Finite lattices and latice boundaries
Infinite cellular automata have no boundary, so it's description B is omitted. But there is no way to simulate an infinite system using a finite system. The simulation must focus on a finite part of the infinite lattice.
The state of a finite lattice cellular automata is a configuration in the lattice SZ, where Z is the set of n integer cell indexes {0,1,...,n − 1}
The neighborhood used in the local transition function oversteps the lattice boundary for k0 cells at the left and k − k0 − 1 cells at the right.
There are two common solutions to the overstepping problem:
- the lattice is wraped into a circle (thorus for 2D CA)
- the values of the overstepping parts of the neighborhood are defined explecitely as the boundary B
Cyclic boundaries are frequently used as there is no need to explecetely define the boundary and no external information is introducet into the CA that could otherwise cause interference at the boundaries. Z is a cyclic group of integers modulo n ({0,1,...,n − 1}). The posittion index is calculated as
Explecitely defined boundaries are less common as the simple constant values are useful only for CA where we observe events on a quiescent background. The boundary can be defined as a single set (the left and the right part combined) of cell values of length k − 1 (there is no boundary cell with index 0)
[edit] Example
The commonly known 1D binary CA rule 110 is defined as where
- Z can be finite or infinite
- S = {0,1} is a set of two values
- N = { − 1,0,1} is the neighborhood of size k = 3 with symmetric radius k0 = 1
- f is the next local transition function
000 -> 0 001 -> 0 010 -> 0 011 -> 0 100 -> 0 101 -> 0 110 -> 0 111 -> 0
- B = {b − 1,b1} is the optional boundary usually B = {0,0} choosen not to interfere with the quiescent background of all zeros
[edit] Generalizations
[edit] Multidimensional Cellular Automata
The definition of nD CA is similar to that of 1D CA, the cell space becomes n-dimensional and k and k0 become vectors of length n.
[edit] Higher Order Cellular Automata
The CA is of higher order if not only the presen but past configurations too are used to calculate the futer.
Seccond order local transition functions are often used to construct reversible rules.
[edit] Calculating Cellular Automata preimages
[edit] The De Bruijn diagram of a single cell
The De bruijn diagram is a digraph, where vertexes represent all possible overlappings and arcs represent neighborhoods that that are mapped into the observd cell by the local transition function.
[edit] Overlapping of adjacent neighborhoods
The neighborhoods of a pair of adjacent cells are overlapping. The size of the overlapping is one cell less than the size of the neighborhood k − 1.
[edit] De Bruijn vector
The De Bruijn vector is a formal representation of vertices of the De Bruijn diagram. It consists of | S | k − 1 nonnegative integer entries, one for each of the possible neighborhood overlappings. The entries can have different meanings but a common idea is that the value is greater than 0 if it represents the part of a valid preimage.
di = []
[edit] De Bruijn matrix of a single cell
The local preimage of a single cell is defined by the inverse of it's local transition function:
The De Bruijn matrix D(c) is the transition matrix for the De Bruijn diagram. It is a function of the cell value c. The size of the metrix is a square (the size of the De Bruijn vector).
If the left and the right overlapping represent a neighborhood that maps into the expected output value c
Cellular automata neighborhood overlapping
The De Bruijn diagrams are used to describe the local preimage of a
[edit] The De Bruijn matrix of a string of cells
The De Bruijn matrix of a string of cells is the multiplied chain of single cell matrices
[edit] Global dynamics of cellular automata
[edit] Reversibility of Cellular Automata
The CA rule is reversible, if the global transition function F is bijective (both injective and surjective).
[edit] Injectivity of the global transition function
F is injective, there is at most one preimage for any CA configuration.
So there are no configurations with more than one predecessor.
[edit] Surjectivity of the global transition function
F is injective, there is at least one preimage for any CA configuration.
So there are no configurations without a predecessor (so called Garden of Eden).
[edit] Bijectivity of the global transition function
F is bijective if it is both injective and surjective. For any conficuration there is exactly one predecesor.
[edit] References
[edit] CA deffinition
- Lyman Hurd, What are Cellular Automata (CA)? [1], CA FAQ
- Erica Jen, Enumeration of Preimages in Cellular Automata, Complex Systems 3 (1989) 421-456
- Hidenosuke Nishio, Information Dynamics of Cellular Automata II: Completness, Degeneracy and Entropy
- Stephen Wolfram, A New Kind of Science
[edit] De Bruijn diagram
- Harold V. McIntosh, Linear Cellular Automata Via de Bruijn Diagrams [2]
[edit] Software
- DDLab by Andy Wuensche