Search
Exact matches only
Search in title
Search in content
Search in comments
Search in excerpt
Filter by Custom Post Type
{ "homeurl": "http://complexityacademy.io/", "resultstype": "isotopic", "resultsposition": "block", "itemscount": 4, "imagewidth": 70, "imageheight": 70, "resultitemheight": "70px", "showauthor": 0, "showdate": 0, "showdescription": 0, "charcount": 3, "noresultstext": "No results!", "didyoumeantext": "Did you mean:", "defaultImage": "http://solutionslab.io/academy/wp-content/uploads/sites/4/2016/10/Search-defualt.jpg", "highlight": 0, "highlightwholewords": 1, "openToBlank": 0, "scrollToResults": 0, "resultareaclickable": 1, "autocomplete": { "enabled": 1, "googleOnly": 1, "lang": "en", "mobile": 1 }, "triggerontype": 1, "triggeronclick": 1, "triggeronreturn": 1, "triggerOnFacetChange": 1, "trigger": { "delay": 300, "autocomplete_delay": 310 }, "overridewpdefault": 0, "override_method": "post", "redirectonclick": 0, "redirectClickTo": "results_page", "redirect_on_enter": 0, "redirectEnterTo": "results_page", "redirect_url": "?s={phrase}", "settingsimagepos": "right", "settingsVisible": 0, "hresulthidedesc": "1", "prescontainerheight": "400px", "pshowsubtitle": "0", "pshowdesc": "1", "closeOnDocClick": 1, "iifNoImage": "description", "iiRows": 2, "iiGutter": 5, "iitemsWidth": 200, "iitemsHeight": 200, "iishowOverlay": 1, "iiblurOverlay": 1, "iihideContent": 1, "loaderLocation": "auto", "analytics": 0, "analyticsString": "", "show_more": { "url": "?s={phrase}", "action": "ajax" }, "mobile": { "trigger_on_type": 1, "trigger_on_click": 1, "hide_keyboard": 0, "force_res_hover": 0, "force_sett_hover": 0, "force_sett_state": "closed" }, "compact": { "enabled": 0, "width": "100%", "closeOnMagnifier": 1, "closeOnDocument": 0, "position": "static", "overlay": 0 }, "animations": { "pc": { "settings": { "anim" : "fadedrop", "dur" : 300 }, "results" : { "anim" : "fadedrop", "dur" : 300 }, "items" : "fadeInDown" }, "mob": { "settings": { "anim" : "fadedrop", "dur" : 300 }, "results" : { "anim" : "fadedrop", "dur" : 300 }, "items" : "voidanim" } }, "autop": { "state": "disabled", "phrase": "", "count": 10 }, "fss_layout": "column" }

Cellular Automaton

Cellular automaton can produce patterns such as those seen on the side of this sea shell

Cellular automaton can produce patterns such as those seen on the side of this sea shell

Cellular automata are algorithmic models that use computation to iterate on very simple rules. In so doing, these very simple rules can create complex emergent phenomena through the interaction between agents as they evolve over time. To illustrate the functioning of a cellular automaton, we will take an example from probably the most famous algorithm called the Game Of Life devised by the mathematician John Conway.
The Game Of Life is played on a grid of square cells. A cell can be alive or dead. A live cell is shown by putting a mark on its square. A dead cell is shown by leaving the square empty, each cell in the grid has a neighborhood consisting of all adjacent cells to it and there are just three rules governing the behavior of an agent. 1. Any live cell with fewer than two live neighbors dies; as if caused by under-population. 2. Any live cell with two or three live neighbors lives on to the next generation. 3. Any live cell with more than three live neighbors dies, as if by overcrowding. 4. Any dead cell with exactly three live neighbors becomes a live cell, as if by reproduction.1

Types Of Patterns

Cellular automata rule sets may be classified according to the degree of complexity that they can produce with Stephen Wolfram’s classification being the first attempt to classify the rules themselves in order of complexity.2 The most simple pattern is called still life. Its product is probably the most simple class of pattern, called class one, where nearly all of these patterns evolve quickly into a stable, homogeneous state and any randomness in the initial pattern disappears. The second class of pattern we may get is where the system evolves into an oscillating structure. The simplest of these being a blinker that has a period two oscillation.
We can also have oscillating structures that cycle over prolonged periods of time. For example, a pulsar has a period three oscillation, but oscillators of many more periods are known to exist. Class three patterns are random, where nearly all initial patterns evolve in a semi-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. Here we can get what are called gliders where a group of cells appears to glide across the screen. This is a good example of emergence as we no longer see the simple rules that are producing them but instead this emergent structure of an object gliding. Lastly, automata can also produce patterns that become complex and endure over a prolonged period of time, with stable local structures. With these more complex patterns, cellular automata can simulate a variety of real-world systems, including biological and chemical ones.

Universal Computation

Since the advent of the Game of Life, new similar cellular automata have been developed that can do all sorts of things, such as create fractal patterns, that is, self-similar structures that repeat themselves over various scales of magnitude. Other games create patterns that can reproduce themselves. We might ask, is there anything that these automata can not do? From the perspective of computation, the Game Of Life can do anything that a computer can do. It can count to 100, calculate the volume of a cylinder, or if you wanted to figure out the cube root of 1230 you could encode this into a set of cells on the automaton and have it compute the value. The Game Of Life as simple as it is has been proven by computer scientists to be capable of universal computation.3

Computational Models

Cellular automaton illustrate one of the central premises of complexity theory, namely that simple rules can in fact produce complex phenomena through iteration and interaction

Cellular automata illustrate one of the central premises of complexity theory, namely that simple rules can, in fact, produce complex phenomena through iteration and interaction

Cellular automata represent a new approach to mathematical modeling based upon computation. Von Neumann and Ulam originally introduced the concept in the mid-20th century, and then a few decades later the popular Game of Life brought interest to the subject beyond academia. In the 80s, Stephen Wolfram engaged in a systematic study of cellular automata after which he published a book called “A New Kind of Science” claiming that cellular automata could enable a new approach based upon the exploration of these algorithms.4 One assumption within modern science is that simple rules can only create simple phenomena, and thus inversely complex phenomena must be the product of complex rules. The advent of chaos theory during the past few decades revealed this to be an invalid assumption as simple systems like a double pendulum proved to be capable of generating complex and chaotic behavior.5 It is now increasingly accepted that complexity may not be the product of complex rules, but in fact, emerge out of the interaction of simple rules as they evolve over time. Cellular automata are the tools that capture and embody this paradigm within science.

Cite this article as: Joss Colchester, "Cellular Automaton," in Complexity Academy, July 15, 2015, http://complexityacademy.io/cellular-automaton/.

  1. View Source
  2. View Source
  3. View Source
  4. View Source
  5. View Source