# Cellular automaton

A **cellular automaton** (pl. **cellular automata**, abbrev. **CA**) is a discrete model studied in computability theory, mathematics, physics, complexity science, theoretical biology and microstructure modeling. Cellular automata are also called **cellular spaces**, tessellation **automata**, **homogeneous structures**, **cellular structures**, **tessellation structures**, and **iterative arrays**.^{[2]}

A cellular automaton consists of a regular grid of *cells*, each in one of a finite number of *states*, such as *on* and *off* (in contrast to a coupled map lattice). The grid can be in any finite number of dimensions. For each cell, a set of cells called its *neighborhood* is defined relative to the specified cell. An initial state (time *t*=0) is selected by assigning a state for each cell. A new *generation* is created (advancing *t* by 1), according to some fixed *rule* (generally, a mathematical function) that determines the new state of each cell in terms of the current state of the cell and the states of the cells in its neighborhood. Typically, the rule for updating the state of cells is the same for each cell and does not change over time, and is applied to the whole grid simultaneously, though exceptions are known, such as the stochastic cellular automaton and asynchronous cellular automaton.

The concept was originally discovered in the 1940s by Stanislaw Ulam and John von Neumann while they were contemporaries at Los Alamos National Laboratory. While studied by some throughout the 1950s and 1960s, it was not until the 1970s and Conway's Game of Life, a two-dimensional cellular automaton, that interest in the subject expanded beyond academia. In the 1980s, Stephen Wolfram engaged in a systematic study of one-dimensional cellular automata, or what he calls elementary cellular automata; his research assistant Matthew Cook showed that one of these rules is Turing-complete. Wolfram published *A New Kind of Science* in 2002, claiming that cellular automata have applications in many fields of science. These include computer processors and cryptography.

The primary classifications of cellular automata as outlined by Wolfram are numbered one to four. They are, in order, automata in which patterns generally stabilize into homogenity, automata in which patterns evolve into mostly stable or oscillating structures, automata in which patterns evolve in a seemingly chaotic fashion, and automata in which patterns become extremely complex and may last for a long time, with stable local structures. This last class are thought to be computationally universal, or capable of simulating a Turing machine. Special types of cellular automata are those which are *reversible*, in which only a single configuration leads directly to a subsequent one, and *totalistic*, in which the future value of individual cells depend on the total value of a group of neighboring cells. Cellular automata can simulate a variety of real-world systems, including biological and chemical ones.

## Contents

## Overview

One way to simulate a two-dimensional cellular automaton is with an infinite sheet of graph paper along with a set of rules for the cells to follow. Each square is called a "cell" and each cell has two possible states, black and white. The *neighborhood* of a cell is the nearby, usually adjacent, cells. The two most common types of neighborhoods are the *von Neumann neighborhood* and the *Moore neighborhood*.^{[3]} The former, named after the founding cellular automaton theorist, consists of the four orthogonally adjacent cells.^{[3]} The latter includes the von Neumann neighborhood as well as the four remaining cells surrounding the cell whose state is to be calculated.^{[3]} For such a cell and its Moore neighborhood, there are 512 (= 2^{9}) possible patterns. For each of the 512 possible patterns, the rule table would state whether the center cell will be black or white on the next time interval. Conway's Game of Life is a popular version of this model. Another common neighborhood type is the *extended von Neumann neighborhood*, which includes the two closest cells in each orthogonal direction, for a total of eight.^{[3]} The general equation for such a system of rules is *k*^{ks}, where *k* is the number of possible states for a cell, and *s* is the number of neighboring cells (including the cell to be calculated itself) used to determine the cell's next state.^{[4]} Thus, in the two dimensional system with a Moore neighborhood, the total number of automata possible would be 2^{29}, or Template:Val.

It is usually assumed that every cell in the universe starts in the same state, except for a finite number of cells in other states; the assignment of state values is called a *configuration*.^{[5]} More generally, it is sometimes assumed that the universe starts out covered with a periodic pattern, and only a finite number of cells violate that pattern. The latter assumption is common in one-dimensional cellular automata.

Cellular automata are often simulated on a finite grid rather than an infinite one. In two dimensions, the universe would be a rectangle instead of an infinite plane. The obvious problem with finite grids is how to handle the cells on the edges. How they are handled will affect the values of all the cells in the grid. One possible method is to allow the values in those cells to remain constant. Another method is to define neighborhoods differently for these cells. One could say that they have fewer neighbors, but then one would also have to define new rules for the cells located on the edges. These cells are usually handled with a *toroidal* arrangement: when one goes off the top, one comes in at the corresponding position on the bottom, and when one goes off the left, one comes in on the right. (This essentially simulates an infinite periodic tiling, and in the field of partial differential equations is sometimes referred to as *periodic* boundary conditions.) This can be visualized as taping the left and right edges of the rectangle to form a tube, then taping the top and bottom edges of the tube to form a torus (doughnut shape). Universes of other dimensions are handled similarly. This is done in order to solve boundary problems with neighborhoods, but another advantage of this system is that it is easily programmable using modular arithmetic functions. For example, in a 1-dimensional cellular automaton like the examples below, the neighborhood of a cell *x _{i}^{t}* is {

*x*

_{i−1}

^{t−1},

*x*

_{i}

^{t−1},

*x*

_{i+1}

^{t−1}}, where

*t*is the time step (vertical), and

*i*is the index (horizontal) in one generation.

## History

Stanislaw Ulam, while working at the Los Alamos National Laboratory in the 1940s, studied the growth of crystals, using a simple lattice network as his model.^{[6]} At the same time, John von Neumann, Ulam's colleague at Los Alamos, was working on the problem of self-replicating systems.^{[7]} Von Neumann's initial design was founded upon the notion of one robot building another robot. This design is known as the kinematic model.^{[8]}^{[9]} As he developed this design, von Neumann came to realize the great difficulty of building a self-replicating robot, and of the great cost in providing the robot with a "sea of parts" from which to build its replicant. Neumann read a paper entitled "The general and logical theory of automata" at the Hixon Symposium in 1948.^{[7]} Ulam was the one who suggested using a *discrete* system for creating a reductionist model of self-replication.^{[10]}^{[11]} Nils Aall Barricelli performed many of the earliest explorations of these models of artificial life.

Ulam and von Neumann created a method for calculating liquid motion in the late 1950s. The driving concept of the method was to consider a liquid as a group of discrete units and calculate the motion of each based on its neighbors' behaviors.^{[12]} Thus was born the first system of cellular automata. Like Ulam's lattice network, von Neumann's cellular automata are two-dimensional, with his self-replicator implemented algorithmically. The result was a universal copier and constructor working within a cellular automaton with a small neighborhood (only those cells that touch are neighbors; for von Neumann's cellular automata, only orthogonal cells), and with 29 states per cell.^{[13]} Von Neumann gave an existence proof that a particular pattern would make endless copies of itself within the given cellular universe by designing a 200,000 cell configuration that could do so.^{[13]} This design is known as the tessellation model, and is called a von Neumann universal constructor.^{[14]}

Also in the 1940s, Norbert Wiener and Arturo Rosenblueth developed a model of excitable media with some of the characteristics of a cellular automaton.^{[15]} Their specific motivation was the mathematical description of impulse conduction in cardiac systems. However their model is not a cellular automaton because the medium in which signals propagate is continuous, and wave fronts are curves.^{[15]}^{[16]} A true cellular automaton model of excitable media was developed and studied by J. M. Greenberg and S. P. Hastings in 1978; see Greenberg-Hastings cellular automaton. The original work of Wiener and Rosenblueth contains many insights and continues to be cited in modern research publications on cardiac arrhythmia and excitable systems.^{[17]}

In the 1960s, cellular automata were studied as a particular type of dynamical system and the connection with the mathematical field of symbolic dynamics was established for the first time. In 1969, Gustav A. Hedlund compiled many results following this point of view^{[18]} in what is still considered as a seminal paper for the mathematical study of cellular automata. The most fundamental result is the characterization in the Curtis–Hedlund–Lyndon theorem of the set of global rules of cellular automata as the set of continuous endomorphisms of shift spaces.

In 1969, German computer pioneer Konrad Zuse published his book *Calculating Space*, proposing that the physical laws of the universe are discrete by nature, and that the entire universe is the output of a deterministic computation on a single cellular automaton; "Zuse's Theory" became the foundation of the field of study called *digital physics*.^{[19]}

In the 1970s a two-state, two-dimensional cellular automaton named Game of Life became widely known, particularly among the early computing community. Invented by John Conway and popularized by Martin Gardner in a *Scientific American* article,^{[20]} its rules are as follows: If a cell has two black neighbors, it stays the same. If it has three black neighbors, it becomes black. In all other situations it becomes white. Despite its simplicity, the system achieves an impressive diversity of behavior, fluctuating between apparent randomness and order. One of the most apparent features of the Game of Life is the frequent occurrence of *gliders*, arrangements of cells that essentially move themselves across the grid. It is possible to arrange the automaton so that the gliders interact to perform computations, and after much effort it has been shown that the Game of Life can emulate a universal Turing machine.^{[21]} It was viewed as a largely recreational topic, and little follow-up work was done outside of investigating the particularities of the Game of Life and a few related rules in the early 1970s.^{[22]}

Stephen Wolfram independently began working on cellular automata in mid 1981 after considering how complex patterns seemed to be formed in nature in violation of the Second Law of Thermodynamics.^{[23]} His investigations were initially spurred by an interest in modelling systems such as neural networks.^{[23]} He published his first paper in *Reviews of Modern Physics* investigating *elementary cellular automata* (Rule 30 in particular) in June 1983.^{[2]}^{[23]} The unexpected complexity of the behavior of these simple rules led Wolfram to suspect that complexity in nature may be due to similar mechanisms.^{[23]} His investigations, however, led him to realize that cellular automata were poor at modelling neural networks.^{[23]} Additionally, during this period Wolfram formulated the concepts of intrinsic randomness and computational irreducibility,^{[24]} and suggested that rule 110 may be universal—a fact proved later by Wolfram's research assistant Matthew Cook in the 1990s.^{[25]}

In 2002 Wolfram published a 1280-page text *A New Kind of Science*, which extensively argues that the discoveries about cellular automata are not isolated facts but are robust and have significance for all disciplines of science.^{[26]} Despite confusion in the press,^{[27]}^{[28]} the book did not argue for a fundamental theory of physics based on cellular automata,^{[29]} and although it did describe a few specific physical models based on cellular automata,^{[30]} it also provided models based on qualitatively different abstract systems.^{[31]}

## Classification

Wolfram, in *A New Kind of Science* and several papers dating from the mid-1980s, defined four classes into which cellular automata and several other simple computational models can be divided depending on their behavior. While earlier studies in cellular automata tended to try to identify type of patterns for specific rules, Wolfram's classification was the first attempt to classify the rules themselves. In order of complexity the classes are:

- Class 1: Nearly all initial patterns evolve quickly into a stable, homogeneous state. Any randomness in the initial pattern disappears.
^{[32]} - Class 2: Nearly all initial patterns evolve quickly into stable or oscillating structures. Some of the randomness in the initial pattern may filter out, but some remains. Local changes to the initial pattern tend to remain local.
^{[32]} - Class 3: Nearly all initial patterns evolve in a pseudo-random or chaotic manner. Any stable structures that appear are quickly destroyed by the surrounding noise. Local changes to the initial pattern tend to spread indefinitely.
^{[32]} - Class 4: Nearly all initial patterns evolve into structures that interact in complex and interesting ways, with the formation of local structures that are able to survive for long periods of time.
^{[33]}Class 2 type stable or oscillating structures may be the eventual outcome, but the number of steps required to reach this state may be very large, even when the initial pattern is relatively simple. Local changes to the initial pattern may spread indefinitely. Wolfram has conjectured that many, if not all class 4 cellular automata are capable of universal computation. This has been proven for Rule 110 and Conway's game of Life.

These definitions are qualitative in nature and there is some room for interpretation. According to Wolfram,
"...with almost any general classification scheme there are inevitably cases which get assigned to one class by one definition and another class by another definition. And so it is with cellular automata: there are occasionally rules...that show some features of one class and some of another."^{[34]} Wolfram's classification has been empirically matched to a clustering of the compressed lengths of the outputs of cellular automata.^{[35]}

There have been several attempts to classify cellular automata in formally rigorous classes, inspired by the Wolfram's classification. For instance, Culik and Yu proposed three well-defined classes (and a fourth one for the automata not matching any of these), which are sometimes called Culik-Yu classes; membership in these proved to be undecidable.^{[36]}^{[37]}^{[38]}
Wolfram's class 2 can be partitioned into two subgroups of stable (fixed-point) and oscillating (periodic) rules.^{[39]}

### Reversible

{{#invoke:main|main}}
A cellular automaton is said to be *reversible* if for every current configuration of the cellular automaton there is exactly one past configuration (preimage).^{[40]} If one thinks of a cellular automaton as a function mapping configurations to configurations, reversibility implies that this function is bijective.^{[40]} If a cellular automaton is reversible, its time-reversed behavior can also be described as a cellular automaton; this fact is a consequence of the Curtis–Hedlund–Lyndon theorem, a topological characterization of cellular automata.^{[41]}^{[42]} For cellular automata in which not every configuration has a preimage, the configurations without preimages are called *Garden of Eden* patterns.^{[43]}

For one-dimensional cellular automata there are known algorithms for deciding whether a rule is reversible or irreversible.^{[44]}^{[45]} However, for cellular automata of two or more dimensions reversibility is undecidable; that is, there is no algorithm that takes as input an automaton rule and is guaranteed to determine correctly whether the automaton is reversible. The proof by Jarkko Kari is related to the tiling problem by Wang tiles.^{[46]}

Reversible cellular automata are often used to simulate such physical phenomena as gas and fluid dynamics, since they obey the laws of thermodynamics. Such cellular automata have rules specially constructed to be reversible. Such systems have been studied by Tommaso Toffoli, Norman Margolus and others. Several techniques can be used to explicitly construct reversible cellular automata with known inverses. Two common ones are the second order cellular automaton and the block cellular automaton, both of which involve modifying the definition of a cellular automaton in some way. Although such automata do not strictly satisfy the definition given above, it can be shown that they can be emulated by conventional cellular automata with sufficiently large neighborhoods and numbers of states, and can therefore be considered a subset of conventional cellular automata. Conversely, it has been shown that every reversible cellular automaton can be emulated by a block cellular automaton.^{[47]}^{[48]}

### Totalistic

A special class of cellular automata are *totalistic* cellular automata. The state of each cell in a totalistic cellular automaton is represented by a number (usually an integer value drawn from a finite set), and the value of a cell at time *t* depends only on the *sum* of the values of the cells in its neighborhood (possibly including the cell itself) at time *t*−1.^{[49]}^{[50]} If the state of the cell at time *t* does depend on its own state at time *t*−1 then the cellular automaton is properly called *outer totalistic*.^{[50]} Conway's Game of Life is an example of an outer totalistic cellular automaton with cell values 0 and 1; outer totalistic cellular automata with the same Moore neighborhood structure as Life are sometimes called [[Template:Not a typo cellular automaton|Template:Not a typo cellular automata]].^{[51]}^{[52]}

### Related automata

There are many possible generalizations of the cellular automaton concept.

One way is by using something other than a rectangular (cubic, *etc.*) grid. For example, if a plane is tiled with regular hexagons, those hexagons could be used as cells. In many cases the resulting cellular automata are equivalent to those with rectangular grids with specially designed neighborhoods and rules. Another variation would be to make the grid itself irregular, such as with Penrose tiles.^{[53]}

Also, rules can be probabilistic rather than deterministic. Such cellular automata are called probabilistic cellular automata. A probabilistic rule gives, for each pattern at time *t*, the probabilities that the central cell will transition to each possible state at time *t*+1. Sometimes a simpler rule is used; for example: "The rule is the Game of Life, but on each time step there is a 0.001% probability that each cell will transition to the opposite color."

The neighborhood or rules could change over time or space. For example, initially the new state of a cell could be determined by the horizontally adjacent cells, but for the next generation the vertical cells would be used.

In cellular automata, the new state of a cell is not affected by the new state of other cells. This could be changed so that, for instance, a 2 by 2 block of cells can be determined by itself and the cells adjacent to itself.

There are *continuous automata*. These are like totalistic cellular automata, but instead of the rule and states being discrete (*e.g.* a table, using states {0,1,2}), continuous functions are used, and the states become continuous (usually values in [0,1]). The state of a location is a finite number of real numbers. Certain cellular automata can yield diffusion in liquid patterns in this way.

Continuous spatial automata have a continuum of locations. The state of a location is a finite number of real numbers. Time is also continuous, and the state evolves according to differential equations. One important example is reaction-diffusion textures, differential equations proposed by Alan Turing to explain how chemical reactions could create the stripes on zebras and spots on leopards.^{[54]} When these are approximated by cellular automata, they often yield similar patterns. MacLennan [1] considers continuous spatial automata as a model of computation.

There are known examples of continuous spatial automata which exhibit propagating phenomena analogous to gliders in the Game of Life.^{[55]}

## Elementary cellular automata

{{#invoke:main|main}}
The simplest nontrivial cellular automaton would be one-dimensional, with two possible states per cell, and a cell's neighbors defined to be the adjacent cells on either side of it. A cell and its two neighbors form a neighborhood of 3 cells, so there are 2^{3}=8 possible patterns for a neighborhood. A rule consists of deciding, for each pattern, whether the cell will be a 1 or a 0 in the next generation. There are then 2^{8}=256 possible rules.^{[4]} These 256 cellular automata are generally referred to by their Wolfram code, a standard naming convention invented by Wolfram that gives each rule a number from 0 to 255. A number of papers have analyzed and compared these 256 cellular automata. The rule 30 and rule 110 cellular automata are particularly interesting. The images below show the history of each when the starting configuration consists of a 1 (at the top of each image) surrounded by 0s. Each row of pixels represents a generation in the history of the automaton, with *t*=0 being the top row. Each pixel is colored white for 0 and black for 1.

**Rule 30 cellular automaton**

current pattern | 111 | 110 | 101 | 100 | 011 | 010 | 001 | 000 |
---|---|---|---|---|---|---|---|---|

new state for center cell | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |

**Rule 110 cellular automaton**

current pattern | 111 | 110 | 101 | 100 | 011 | 010 | 001 | 000 |
---|---|---|---|---|---|---|---|---|

new state for center cell | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 |

Rule 30 exhibits *class 3* behavior, meaning even simple input patterns such as that shown lead to chaotic, seemingly random histories.

Rule 110, like the Game of Life, exhibits what Wolfram calls *class 4* behavior, which is neither completely random nor completely repetitive. Localized structures appear and interact in various complicated-looking ways. In the course of the development of *A New Kind of Science*, as a research assistant to Wolfram in 1994, Matthew Cook proved that some of these structures were rich enough to support universality. This result is interesting because rule 110 is an extremely simple one-dimensional system, and one which is difficult to engineer to perform specific behavior. This result therefore provides significant support for Wolfram's view that class 4 systems are inherently likely to be universal. Cook presented his proof at a Santa Fe Institute conference on Cellular Automata in 1998, but Wolfram blocked the proof from being included in the conference proceedings, as Wolfram did not want the proof to be announced before the publication of *A New Kind of Science*.^{[56]} In 2004, Cook's proof was finally published in Wolfram's journal *Complex Systems* (Vol. 15, No. 1), over ten years after Cook came up with it. Rule 110 has been the basis over which some of the smallest universal Turing machines have been built.^{[57]}

## Rule space

An elementary cellular automaton rule is specified by 8 bits, and all elementary cellular automaton rules can be considered to sit on the vertices of the 8-dimensional unit hypercube. This unit hypercube is the cellular automaton rule space. For next-nearest-neighbor cellular automata, a rule is specified by bits, and the cellular automaton rule space is a 32-dimensional unit hypercube. A distance between two rules can be defined by the number of steps required to move from one vertex, which represents the first rule, and another vertex, representing another rule, along the edge of the hypercube. This rule-to-rule distance is also called the Hamming distance.

Cellular automaton rule space allows us to ask the question concerning whether rules with similar dynamical behavior are ``close" to each. Graphically drawing a high dimensional hypercube on the 2-dimensional plane remains a difficult task, and one crude locator of a rule in the hypercube is the number of bit-1 in the 8-bit string for elementary rules (or 32-bit string for the next-nearest-neighbor rules). Drawing the rules in different Wolfram classes in these slices of the rule space show that class 1 rules tend to have lower number of bit-1's, thus located in one region of the space, whereas class 3 rules tend to have higher proportion (50%) of bit-1's.^{[39]}

For larger cellular automaton rule space, it is shown that class 4 rules are located between the class 1 and class 3 rules.^{[58]} This observation is the foundation for the phrase edge of chaos, and is reminiscent of the phase transition in thermodynamics.

## Biology

Some biological processes occur—or can be simulated—by cellular automata.

Patterns of some seashells, like the ones in *Conus* and *Cymbiola* genus, are generated by natural cellular automata. The pigment cells reside in a narrow band along the shell's lip. Each cell secretes pigments according to the activating and inhibiting activity of its neighbor pigment cells, obeying a natural version of a mathematical rule.^{[59]} The cell band leaves the colored pattern on the shell as it grows slowly. For example, the widespread species *Conus textile* bears a pattern resembling Wolfram's rule 30 cellular automaton.^{[59]}

Plants regulate their intake and loss of gases via a cellular automaton mechanism. Each stoma on the leaf acts as a cell.^{[60]}

Moving wave patterns on the skin of cephalopods can be simulated with a two-state, two-dimensional cellular automata, each state corresponding to either an expanded or retracted chromatophore.^{[61]}

Threshold automata have been invented to simulate neurons, and complex behaviors such as recognition and learning can be simulated.^{[62]}

Fibroblasts bear similarities to cellular automata, as each fibroblast only interacts with its neighbors.^{[63]}

## Chemical types

The Belousov–Zhabotinsky reaction is a spatio-temporal chemical oscillator which can be simulated by means of a cellular automaton. In the 1950s A. M. Zhabotinsky (extending the work of B. P. Belousov) discovered that when a thin, homogenous layer of a mixture of malonic acid, acidified bromate, and a ceric salt were mixed together and left undisturbed, fascinating geometric patterns such as concentric circles and spirals propagate across the medium. In the "Computer Recreations" section of the August 1988 issue of *Scientific American*,^{[64]} A. K. Dewdney discussed a cellular automaton^{[65]} which was developed by Martin Gerhardt and Heike Schuster of the University of Bielefeld (West Germany). This automaton produces wave patterns resembling those in the Belousov-Zhabotinsky reaction.

## Applications

### Computer processors

Cellular automaton processors are physical implementations of CA concepts, which can process information computationally. Processing elements are arranged in a regular grid of identical cells. The grid is usually a square tiling, or tessellation, of two or three dimensions; other tilings are possible, but not yet used. Cell states are determined only by interactions with adjacent neighbor cells. No means exists to communicate directly with cells farther away.^{[66]} One such cellular automaton processor array configuration is the systolic array. Cell interaction can be via electric charge, magnetism, vibration (phonons at quantum scales), or any other physically useful means. This can be done in several ways so no wires are needed between any elements. This is very unlike processors used in most computers today, von Neumann designs, which are divided into sections with elements that can communicate with distant elements over wires.

### Cryptography

Rule 30 was originally suggested as a possible Block cipher for use in cryptography. Two dimensional cellular automata are used for random number generation.^{[67]}

Cellular automata have been proposed for public key cryptography. The one-way function is the evolution of a finite CA whose inverse is believed to be hard to find. Given the rule, anyone can easily calculate future states, but it appears to be very difficult to calculate previous states.

### Error correction coding

CA have been applied to design error correction codes in the paper "Design of CAECC – Cellular Automata Based Error Correcting Code", by D. Roy Chowdhury, S. Basu, I. Sen Gupta, P. Pal Chaudhuri. The paper defines a new scheme of building SEC-DED codes using CA, and also reports a fast hardware decoder for the code.

## Modeling physical reality

{{#invoke:main|main}}
As Andrew Ilachinski points out in his *Cellular Automata*, many scholars have raised the question of whether the universe is a cellular automaton.^{[68]} Ilachinski argues that the importance of this question may be better appreciated with a simple observation, which can be stated as follows. Consider the evolution of rule 110: if it were some kind of "alien physics", what would be a reasonable description of the observed patterns?^{[69]} If you didn't know how the images were generated, you might end up conjecturing about the movement of some particle-like objects (indeed, physicist James Crutchfield made a rigorous mathematical theory out of this idea proving the statistical emergence of "particles" from CA).^{[70]} Then, as the argument goes, one might wonder if *our* world, which is currently well described by physics with particle-like objects, could be a CA at its most fundamental level.

While a complete theory along this line is still to be developed, entertaining and developing this hypothesis led scholars to interesting speculation and fruitful intuitions on how can we make sense of our world within a discrete framework. Marvin Minsky, the AI pioneer, investigated how to understand particle interaction with a four-dimensional CA lattice;^{[71]} Konrad Zuse—the inventor of the first working computer, the Z3—developed an irregularly organized lattice to address the question of the information content of particles.^{[72]} More recently, Edward Fredkin exposed what he terms the "finite nature hypothesis", i.e., the idea that "ultimately every quantity of physics, including space and time, will turn out to be discrete and finite."^{[73]} Fredkin and Wolfram are strong proponents of a CA-based physics.

In recent years, other suggestions along these lines have emerged from literature in non-standard computation. Wolfram's *A New Kind of Science* considers CA to be the key to understanding a variety of subjects, physics included. The *Mathematics Of the Models of Reference*—created by iLabs^{[74]} founder Gabriele Rossi and developed with Francesco Berto and Jacopo Tagliabue—features an original 2D/3D universe based on a new "rhombic dodecahedron-based" lattice and a unique rule. This model satisfies universality (it is equivalent to a Turing Machine) and perfect reversibility (a *desideratum* if one wants to conserve various quantities easily and never lose information), and it comes embedded in a first-order theory, allowing computable, qualitative statements on the universe evolution.^{[75]}

## See also

### Specific rules

- Brian's Brain
- Langton's ant
- Wireworld
- Rule 90
- Rule 184
- von Neumann cellular automata
- Nobili cellular automata
- Codd's cellular automaton
- Langton's loops
- CoDi

### Problems solved

### See also

- Automata theory
- Bidirectional traffic
- Cellular automata in popular culture
- Cyclic cellular automaton
- Excitable medium
- Quantum cellular automata
- Spatial decision support system
- Mirek's Cellebration
- Movable cellular automaton

## Reference notes

- ↑ Daniel Dennett (1995),
*Darwin's Dangerous Idea*, Penguin Books, London, ISBN 978-0-14-016734-4, ISBN 0-14-016734-X - ↑
^{2.0}^{2.1}{{#invoke:Citation/CS1|citation |CitationClass=journal }} - ↑
^{3.0}^{3.1}^{3.2}^{3.3}Template:Harvnb - ↑
^{4.0}^{4.1}Template:Harvnb - ↑ Template:Harvnb
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑
^{7.0}^{7.1}Template:Harvnb - ↑ John von Neumann, “The general and logical theory of automata,” in L.A. Jeffress, ed., Cerebral Mechanisms in Behavior – The Hixon Symposium, John Wiley & Sons, New York, 1951, pp. 1–31.
- ↑ John G. Kemeny, “Man viewed as a machine,” Sci. Amer. 192(April 1955):58–67; Sci. Amer. 192(June 1955):6 (errata).
- ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑
^{13.0}^{13.1}Template:Harvnb - ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑
^{15.0}^{15.1}{{#invoke:Citation/CS1|citation |CitationClass=journal }} - ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Template:Harvnb
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Paul Chapman. Life universal computer. http://www.igblan.free-online.co.uk/igblan/ca/ November 2002
- ↑ Template:Harvnb
- ↑
^{23.0}^{23.1}^{23.2}^{23.3}^{23.4}Template:Harvnb - ↑ Template:Harvnb
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Template:Harvnb
- ↑ Template:Cite news
- ↑ Template:Cite news
- ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑
^{32.0}^{32.1}^{32.2}Template:Harvnb - ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑
^{39.0}^{39.1}{{#invoke:Citation/CS1|citation |CitationClass=journal }} - ↑
^{40.0}^{40.1}Template:Harvnb - ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ Template:Harvnb
- ↑ Serafino Amoroso, Yale N. Patt,
*Decision Procedures for Surjectivity and Injectivity of Parallel Maps for Tessellation Structures*. J. Comput. Syst. Sci. 6(5): 448–464 (1972) - ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Template:Harvnb
- ↑
^{50.0}^{50.1}{{#invoke:citation/CS1|citation |CitationClass=book }} - ↑ The phrase "Template:Not a typo cellular automaton" dates back at least to Template:Harvtxt, who used it in a broader sense to refer to outer totalistic automata, not necessarily of two dimensions. The more specific meaning given here was used e.g. in several chapters of Template:Harvtxt. See: {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Template:Harvnb
- ↑ http://www.newscientist.com/article/dn22134-first-gliders-navigate-everchanging-penrose-universe.html
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Pivato, M: "RealLife: The continuum limit of Larger than Life cellular automata",
*Theoretical Computer Science*, 372 (1), March 2007, pp. 46–68 - ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑
^{59.0}^{59.1}^{59.2}{{#invoke:citation/CS1|citation |CitationClass=citation }} - ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ http://gilly.stanford.edu/past_research_files/APackardneuralnet.pdf
- ↑ Template:Harvnb
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ A. K. Dewdney, The hodgepodge machine makes waves, Scientific American, p. 104, August 1988.
- ↑ M. Gerhardt and H. Schuster, A cellular automaton describing the formation of spatially ordered structures in chemical systems, Physica D 36, 209–221, 1989.
- ↑ {{#invoke:citation/CS1|citation |CitationClass=book }}
- ↑ {{#invoke:Citation/CS1|citation |CitationClass=journal }}
- ↑ Template:Harvnb
- ↑ Template:Harvnb
- ↑ J. P. Crutchfield, "The Calculi of Emergence: Computation, Dynamics, and Induction", Physica D 75, 11–54, 1994.
- ↑ M. Minsky, "Cellular Vacuum", International Journal of Theoretical Physics 21, 537–551, 1982.
- ↑ K. Zuse, "The Computing Universe", Int. Jour. of Theo. Phy. 21, 589–600, 1982.
- ↑ E. Fredkin, "Digital mechanics: an informational process based on reversible universal cellular automata", Physica D 45, 254–270, 1990
- ↑ iLabs
- ↑ F. Berto, G. Rossi, J. Tagliabue, The Mathematics of the Models of Reference, College Publications, 2010

## References

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- {{#invoke:citation/CS1|citation

|CitationClass=book }}

- Cellular automaton FAQ from the newsgroup comp.theory.cell-automata
- A. D. Wissner-Gross. 2007.
*Pattern formation without favored local interactions*, Journal of Cellular Automata 4, 27–36 (2008). - "Neighbourhood Survey" (includes discussion on triangular grids, and larger neighborhood CAs)
- von Neumann, John, 1966,
*The Theory of Self-reproducing Automata*, A. Burks, ed., Univ. of Illinois Press, Urbana, IL. - Cosma Shalizi's Cellular Automata Notebook contains an extensive list of academic and professional reference material.
- Wolfram's papers on CAs
- A.M. Turing. 1952. The Chemical Basis of Morphogenesis.
*Phil. Trans. Royal Society*, vol. B237, pp. 37–72. (proposes reaction-diffusion, a type of continuous automaton). - Evolving Cellular Automata with Genetic Algorithms: A Review of Recent Work, Melanie Mitchell, James P. Crutchfeld, Rajarshi Das (In Proceedings of the First International Conference on Evolutionary Computation and Its Applications (EvCA'96). Moscow, Russia: Russian Academy of Sciences, 1996.)
- The Evolutionary Design of Collective Computation in Cellular Automata, James P. Crutchfeld, Melanie Mitchell, Rajarshi Das (In J. P. Crutch¯eld and P. K. Schuster (editors), Evolutionary Dynamics|Exploring the Interplay of Selection, Neutrality, Accident, and Function. New York: Oxford University Press, 2002.)
- The Evolution of Emergent Computation, James P. Crutchfield and Melanie Mitchell (SFI Technical Report 94-03-012)
- Ganguly, Sikdar, Deutsch and Chaudhuri "A Survey on Cellular Automata"

## External links

Template:Sister Template:Sister

- Template:Sep entry
- Mirek's Cellebration – Home to free MCell and MJCell cellular automata explorer software and rule libraries. The software supports a large number of 1D and 2D rules. The site provides both an extensive rules lexicon and many image galleries loaded with examples of rules. MCell is a Windows application, while MJCell is a Java applet. Source code is available.
- Modern Cellular Automata – Easy to use interactive exhibits of live color 2D cellular automata, powered by Java applet. Included are exhibits of traditional, reversible, hexagonal, multiple step, fractal generating, and pattern generating rules. Thousands of rules are provided for viewing. Free software is available.
- Self-replication loops in Cellular Space – Java applet powered exhibits of self replication loops.
- A collection of over 10 different cellular automata applets (in Monash University's Virtual Lab)
- Golly supports von Neumann, Nobili, GOL, and a great many other systems of cellular automata. Developed by Tomas Rokicki and Andrew Trevorrow. This is the only simulator currently available which can demonstrate von Neumann type self-replication.
- Wolfram Atlas – An atlas of various types of one-dimensional cellular automata.
- Conway Life
- First replicating creature spawned in life simulator
*The Mathematics of the Models of Reference*, featuring a general tutorial on CA, interactive applet, free code and resources on CA as model of fundamental physics- Fourmilab Cellular Automata Laboratory
- Busy Boxes, a 3-D, reversible, SALT-architecture CA
- Cellular Automata Repository (CA researchers, historic links, free software, books and beyond)

{{ safesubst:#invoke:Unsubst||$N=Use dmy dates |date=__DATE__ |$B= }}