Zellulärer Automat
Zelluläre oder auch zellulare Automaten dienen der Modellierung räumlich diskreter dynamischer Systeme, wobei die Entwicklung einzelner Zellen zum Zeitpunkt primär von den Zellzuständen in einer vorgegebenen Nachbarschaft und vom eigenen Zustand zum Zeitpunkt abhängt.
Beschreibung
Ein Zellularautomat ist durch folgende Größen festgelegt:
- ein Raum (Zellularraum)
- eine endliche Nachbarschaft
- eine Zustandsmenge
- eine lokale Überführungsfunktion .
Der Zellularraum besitzt eine gewisse Dimensionalität, er ist in der Regel ein- oder zweidimensional, kann aber durchaus auch höherdimensional sein. Man beschreibt das Aussehen eines Zellularautomaten durch eine globale Konfiguration, welche eine Abbildung aus dem Zellularraum in die Zustandsmenge ist, das heißt, man ordnet jeder Zelle des Automaten einen Zustand zu. Der Übergang einer Zelle von einem Zustand (lokale Konfiguration) in den nächsten wird durch Zustandsübergangsregeln definiert, die deterministisch oder stochastisch sein können. Die Zustandsübergänge erfolgen für alle Zellen nach derselben Überführungsfunktion und gleichzeitig. Die Zellzustände können wie die Zeitschritte diskret sein. In der Regel ist die Anzahl der möglichen Zustände klein: Nur wenige Zustandswerte reichen zur Simulation selbst hochkomplexer Systeme aus.
Man unterscheidet zwei verschiedene Nachbarschaften (auch Nachbarschaftsindex genannt):
Geschichte der Zellularautomaten
Zellularautomaten wurden um 1940 von Stanislaw Ulam in Los Alamos vorgestellt. John von Neumann, ein damaliger Kollege Ulams, griff die Idee auf und erweiterte sie zu einem universellen Berechnungsmodell. Er stellte einen Zellularautomaten mit 29 Zuständen vor, der ein gegebenes Muster immer wieder selbst reproduzieren konnte. Er beschrieb damit als erster einen Zellularautomaten, der berechnungs- und konstruktionsuniversell ist. Er ist nach von Neumann geeignet für Probleme biologischer Organisation, Selbstreproduktion und der Evolution von Komplexität. Damit ist der Zellularautomat auch eine wichtige Grundlage für künstliches Leben.
Bis zu den 1960er Jahren waren die Analogrechner den Digitalrechnern bei einigen Fragestellungen überlegen. Ein analoger Zellulärer Automat zur Simulation von Grundwasserströmungen wird im Artikel Analogrechner, Abschnitt „Beispiel: Zellulärer Automat“ genauer beschrieben.
In den 1970er Jahren erlangte John Horton Conways Game of Life Berühmtheit.
1969 veröffentlichte Konrad Zuse sein Buch „Rechnender Raum“, worin er annimmt, dass die Naturgesetze diskreten Regeln folgen und das gesamte Geschehen im Universum das Ergebnis der Arbeit eines gigantischen Zellularautomaten sei.
1983 veröffentlichte Stephen Wolfram eine Reihe von grundlegenden Arbeiten zu Zellularautomaten und 2002 das Buch A New Kind of Science.
Wolframs eindimensionales Universum
Informatiker Stephen Wolframs zellulärer Automat ist ein besonders schönes und einfaches Modell-Universum. Es besteht aus nur einer Raum- und einer Zeitdimension. Im Bild ist die Raumdimension waagerecht eingezeichnet und die Zeitdimension verläuft senkrecht nach unten. (Das Bild enthält drei verschiedene Bildausschnitte.) Die Raumdimension ist endlich, aber unbegrenzt, denn ihr rechtes und linkes Ende sind topologisch miteinander verbunden.
Die Raum-Zeit-Elemente dieses Universums können nur leer oder voll sein. Beim „Urknall“ (in den obersten Bildzeilen) werden diese Raum-Zeit-Elemente mit 50-prozentiger Wahrscheinlichkeit gefüllt. Es gibt nur ein Naturgesetz, das eine Nahwirkung darstellt. Der Nahbereich umfasst die linken zwei Nachbarn eines Raum-Zeit-Elements, das Raum-Zeit-Element selbst, und die rechten zwei Nachbarn des Raum-Zeit-Elements. Wenn zwei oder vier Raum-Zeit-Elemente im Nahbereich voll sind, dann ist im nächsten Zeitintervall dieses Raum-Zeit-Element auch voll, ansonsten ist es im nächsten Zeitintervall leer. Es existieren keine weiteren Regeln.
Obwohl es im Gegensatz zu Computer-Spielen keine Fernwirkung und keinerlei Kontrollinstanz gibt, entwickelt sich dieses Modelluniversum zu verblüffender Komplexität. Nach dem Urknall findet eine Eliminationsphase statt, so wie im echten Universum auch. Danach entstehen kurzlebige, aber geordnete Strukturen, die irgendwann erlöschen. Einige der geordneten Strukturen sind aber langzeitstabil, manche davon oszillieren, andere davon sind in der Zeit formstabil. Sowohl von den oszillierenden als auch von den formstabilen Strukturen existieren sowohl ortsfeste als auch bewegliche Arten. Die maximale Austauschgeschwindigkeit dieses Universums kann nur zwei Raumeinheiten je Zeiteinheit betragen. Wenn zwischen den stabilen bewegten Objekten Kollisionen stattfinden, dann setzt wieder Chaos ein, und eine weitere Eliminationsphase findet statt.
Vereinfacht man noch weiter und berücksichtigt neben dem Zustand des Elementes selbst nur jeweils das rechte und das linke Nachbarelement, gibt es genau 8 Regelelemente. Ein Beispiel dazu steht weiter unten. Insgesamt gibt es 256 solcher Regeln. Selbst unter diesen noch einfacheren Regeln zeigen einige eine erstaunliche Komplexität. Eine der interessantesten ist die „Regel 110“:
Regel 110
neuer Zustand der mittleren Zelle | 0 | 1 | 1 | 0 | 1 | 1 | 1 | 0 |
momentaner Zustand dreier benachbarter Zellen | 111 | 110 | 101 | 100 | 011 | 010 | 001 | 000 |
Siehe auch: Regel 30
Einteilung
Stephen Wolfram definiert in A New Kind of Science und in etlichen Arbeiten aus der Mitte der 1980er-Jahre vier Klassen, in die man die zellulären Automaten (genauer: die Regeln, die sie abarbeiten) je nach ihrem Verhalten unterteilen kann. Frühere Autoren versuchten lediglich, die Art der Muster für bestimmte Vorschriften zu ermitteln.
Dem Aufwand nach geordnet waren dies die Klassen:
- Klasse 1: Fast alle ursprünglichen Muster entwickeln sich schnell zu einem stabilen und homogenen Zustand. Dadurch verschwindet jede Zufälligkeit in den ersten Mustern.
- Klasse 2: Fast alle ursprünglichen Muster entwickeln sich schnell in stabile oder oszillierende Strukturen. Einige Zufälligkeiten der ersten Muster kann man herausfiltern, jedoch können manche zurückbleiben. Lokale Änderungen am ursprünglichen Muster neigen dazu lokal zu bleiben.
- Klasse 3: Fast alle ursprünglichen Muster entwickeln sich pseudozufällig oder chaotisch. Jede stabile Struktur kann schnell durch Rauschen zerstört werden. Lokale Änderungen am ursprünglichen Muster neigen dazu, sich bis ins Unendliche auszubreiten.
- Klasse 4: Fast alle ursprünglichen Muster entwickeln sich in Strukturen, die vielschichtig und interessant interagieren. Endlich informative Ursprungsmuster können, wie in Klasse 2 üblich, stabile oder oszillierende Strukturen ergeben, aber die Anzahl der erforderlichen Schritte, um diesen Zustand zu erreichen, kann selbst für einfache Muster sehr groß sein. Lokale Änderungen am ursprünglichen Muster können sich bis ins Unendliche verbreiten.
Wolfram hat vermutet, dass nicht alle zellulären Automaten der Klasse 4 dazu imstande sind, universelle Berechnungen auszuführen. Die Universalität hat sich vor allem für die Regel 110 und Conways Spiel des Lebens bestätigt.
Zelluläre Automaten programmieren
Dieses kurze Skript, geschrieben in der Programmiersprache Python, kann alle 256 eindimensionalen zellulären Automaten simulieren und erzeugt als Ausgabe ein Bild im Grafikformat Portable Graymap (.pgm). Beim Aufruf muss die gewünschte Regelnummer, 0 bis 255 eingegeben werden.
from optparse import OptionParser
if __name__=="__main__":
parser = OptionParser()
parser.add_option("-r", dest="rule", help="Rule number 0..255.")
parser.add_option("-f", dest="file_path", help="File path")
(option, args) = parser.parse_args()
rule = option.rule
file_path = option.file_path
w = 1000
r = s = [0] * w
r[int(w/2)] = 1
z = []
d = 0
for j in range(0, int(w/2)):
n = (r[0] << 1) + r[1]
o = "" target="_blank" rel="nofollow"
for i in range(1, w):
o += " 0 " if r[i]==1 else "15 "
z.append(o + "\n")
for i in range(2,w):
n = (n << 1) + r[i]
if n >= 8: n-=8
s[i-1] = (int(rule) >> n)%2
r = s
d += 1
f = open(file_path,'w')
f.write("P2\n")
f.write(str(w-1) + " " + str(d) + "\n")
f.write("15\n")
for i in range(len(z)-1, 0, -1):
f.write(z[i])
f.close()
Beispiele für zelluläre Automaten
- Conways Spiel des Lebens (Game of Life) ist ein einfacher zweidimensionaler zellulärer Automat, der verblüffende Strukturen erzeugt.
- Langton-Schleifen simulieren zur Selbstreplikation fähige Organismen in einem zellulären Automaten.
- Das Pascalsche Dreieck kann ebenfalls als einfacher zellulärer Automat interpretiert werden.
- Das Nagel-Schreckenberg-Modell ist ein Zellularautomat zur Simulation des Straßenverkehrs, insbesondere auf Autobahnen.
- Das FHP-Modell dient der Simulation von Gasen und Flüssigkeiten.
- Ein sehr einfacher zellulärer Automat ist der ASEP.
Siehe auch
- Ameise (Turingmaschine)
- Emergenz
- Evakuierungssimulation
- Künstliches Leben
- Musterbildung
- Räuber-Beute-Modell
- Turingmaschine
- Wator
- Wireworld
- Pascalsches Dreieck kann mit zellulären Automaten simuliert werden
- Endlicher Automat
Literatur
- Melanie Mitchell: Complexity. A Guided Tour. Oxford University Press, Oxford u. a. 2009, ISBN 978-0-19-512441-5, eingeschränkte Vorschau in der Google-Buchsuche.
- Klaus Mainzer, Leon Chua: The Universe as Automaton. From Simplicity and Symmetry to Complexity. Springer, Heidelberg u. a. 2012, ISBN 978-3-642-23476-7, eingeschränkte Vorschau in der Google-Buchsuche.
Weblinks
Sekundärliteratur
- Francesco Berto, Jacopo Tagliabue: Cellular Automata. In: Edward N. Zalta (Hrsg.): Stanford Encyclopedia of Philosophy.
- Jürgen Schmidhuber: Webseite über Konrad Zuses Theorie des Rechnenden Raumes (Auszug aus Elektronische Datenverarbeitung 8 (1967) S. 336–344)
Visualisierungen und Implementierungen
- Wolfram’s 1-dimensionales Universum als C#-Implementierung
- 2.5d zellulärer Automat (3d game of life) mit Dokumentation und Quellcode
- Greenberg-Hastings-Automaten (Memento vom 18. Juni 2010 im Internet Archive) als Java-Applet
- Zyklischer Zellulärer Automat als Java-Applet
- Zellomat3D – 3D-zellulärer Automat
- NetLogo[2] – Agenten-basierte Modellierungs- und Simulationsumgebung
- Random Design – Zufallserzeugte zelluläre Automaten
- Ordnungsprozess in einem Monte-Carlo-basierten zellulären Automat (Youtube-Video)
- Otomata – Sequencer als interaktiver zellulärer Automat
- Cafun – Freeware Java Implementierung zur Simulation und Visualisierung zellulärer Automaten mit XML-basierter Konfiguration
- Golly – Simulation zahlreicher verschiedener zellulärer Automaten mit Beispielen
Einzelnachweise
- Daniel Dennett, (1995), Darwin's Dangerous Idea, Penguin Books, London, ISBN 978-0-14-016734-4, ISBN 0-14-016734-X
- NetLogo Models Library: CA 1D Elementary Cellular Automata. Abgerufen am 26. November 2018 (englisch).