Правило 30
Пра́вило 30 (англ. Rule 30) — элементарный клеточный автомат, то есть одномерный клеточный автомат с двумя состояниями (0 и 1), впервые описанный Стивеном Вольфрамом в 1983 году[2]. Стивен Вольфрам говорит, что «это его самое любимое правило», и подробно описывает его в своей книге «A New Kind of Science». Из четырёх типов поведения, описанных в этой книге, Правило 30 обладает классом поведения III, показывая апериодическое, хаотическое поведение.
Правило представляет интерес, потому что оно порождает сложные, во многих отношениях случайные структуры из простых, чётко определенных правил. Вольфрам полагает, что клеточные автоматы в целом и Правило 30 в частности — ключ к пониманию того, как простые правила могут порождать сложные структуры и различное сложное поведение разных природных объектов. Например, структуру, похожую на порождаемую Правилом 30, можно найти на раковине широко распространённого тропического моллюска Conus textile. Правило 30 также используется как генератор псевдослучайных чисел (ГПСЧ) в продукте Wolfram Research — Mathematica[3]. Также это правило было предложено для использования как шифратор последовательностей в криптографии[4].
Однако M. Sipper и M. Tomassini показали, что как ГПСЧ Правило 30 плохо проходит тест на критерий согласия Пирсона (критерий χ²) в сравнении с другими псевдослучайными последовательностями, которые были получены при помощи других клеточных автоматов.
Правило 30 так называется, потому что 30 — наименьший код описания правила поведения клеточных автоматов по Вольфраму, предложенного им в 1983 г. Если записать код правила в двоичном виде, то зеркальное отражение кода правила, инверсия битов кода и зеркальное отображение с инверсией битов имеют в десятичной системе счисления коды 120, 225 и 135 соответственно.
Описание правила
правитьРассматривается бесконечный одномерный массив ячеек (клеток) клеточного автомата с двумя возможными состояниями. Каждая из клеток имеет начальное состояние. В дискретные моменты времени каждая клетка изменяет своё состояние, причем это состояние зависит от предыдущего состояния этой ячейки и предыдущего состояния двух соседних ячеек — клеток-соседей. Для Правила 30 в таблице даны правила перехода центральной клетки триады в следующее состояние, и для сравнения приведены Правила 120, 225 и 135.
Текущее состояние трёх соседних клеток | 111 | 110 | 101 | 100 | 011 | 010 | 001 | 000 |
---|---|---|---|---|---|---|---|---|
по Правилу 30 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 0 |
по Правилу 120 | 0 | 1 | 1 | 1 | 1 | 0 | 0 | 0 |
по Правилу 225 | 1 | 1 | 1 | 0 | 0 | 0 | 0 | 1 |
по Правилу 135 | 1 | 0 | 0 | 0 | 0 | 1 | 1 | 1 |
Двоичные числа 111102 = 3010, 11110002 = 12010, 111000012 = 22510, 100001112 = 13510, именно поэтому эти правила, по Вольфраму, называют правилами 30, 120, 225 и 135 соответственно.
Структура и свойства
правитьПри задании различных начальных состояний клеток Правило 30 порождает разные эволюции последующих поколений клеток.
Для примера приведена эволюция по Правилу 30, начальное состояние которого только одна чёрная клетка, окруженная белыми клетками. (Принято, что чёрная клетка отвечает единичному состоянию клетки по таблице).
На этом изображении по вертикальной оси отложено время, каждый горизонтальный слой отражает состояние всех ячеек клеточного автомата поколения во время эволюции по Правилу 30. На изображении можно заметить несколько особенностей, таких как частое появление белых треугольников разных размеров, что напоминает по форме пятна на раковине моллюска и явную регулярную структуру в левой части изображения. Тем не менее, общая структура рисунка не поддаётся общему регулярному описанию. Количество черных клеток в последующих поколениях эволюции автоматов есть последовательность:
и приблизительно нарастает как — номер поколения.
Как видно из рисунка, Правило 30 порождает последовательность, кажущуюся во многих отношениях случайной, при начальных условиях, которые нельзя назвать случайными. Стивен Вольфрам предложил использование вертикальных столбиков в эволюции клеточных автоматов при некоторой заданном начальном состоянии как псевдослучайную последовательность. Последовательности, полученные таким способом, удовлетворяют многим стандартным тестам на случайность. Стивен Вольфрам использует Правило 30 для генерации случайных целых чисел в пакете Mathematica.
Правило 30 выдает случайные структуры на многих наборах начальных условий. Однако существует и бесконечное количество векторов начальных условий, порождающих в эволюции периодические структуры. Тривиальный пример — вектор начальных условий, состоящий только из белых клеток (0). Менее тривиальный пример, найденный Мэтью Куком — любая бесконечная последовательность, состоящая из повторений шаблона 00001000111000, возможно, разделенных шестью единицами. Ещё больше таких шаблонов было найдено Frans Faase, они представлены здесь Архивная копия от 8 августа 2013 на Wayback Machine.
Детерминированный хаос
правитьВольфрам предположил хаотичность эволюции по Правилу 30, основываясь, в основном, на её внешнем графическом виде. Однако позже было показано, что применение Правила 30 удовлетворяет более строгим определениям хаоса, сформулированным Devaney и Knudson. В соответствии с критерием Devaney, Правило 30 демонстрирует эффект бабочки — (если задать 2 начальных состояния, различающиеся, например, только одним битом, то отдалённые многими поколениями потомки этих 2 состояний будут совершенно различные), периодические конфигурации плотны в пространстве всех конфигураций топологии Кантора. Также, Правило 30 обладает свойством перемешивания. В соответствии с критерием Knudson, это показывает чувствительность к начальным условиям и плотность орбит процесса (любая конфигурация в итоге приводит к возникновению всех возможных конечных конфигураций клеток). Обе этих характеристики хаотичного поведения эволюции по Правилу 30 следуют из свойства Правила 30, которое легко проверить: если две конфигурации C и B различаются на одну клетку в позиции i, тогда после одного шага новые конфигурации будут различаться в клетке i + 1[5].
Галерея
править-
Начальные шаги эволюции Правила 30
-
2000 шагов эволюции Правила 30
-
Примерно 15000 шагов эволюции Правила 30
-
Периодические структуры при эволюции
-
Эволюция при случайных начальных условиях
Ссылки
править- Rule 30: Wolfram’s Pseudo-random Bit Generator Архивная копия от 11 сентября 2019 на Wayback Machine. Recipe 32 at David Griffeath's Primordial Soup Kitchen.
- Weisstein, Eric W. Rule 30 (англ.) на сайте Wolfram MathWorld.
- Repeating Rule 30 patterns Архивная копия от 8 августа 2013 на Wayback Machine. Список начальных условий, результатом эволюции которых являются повторяющиеся последовательности. Frans Faase, 2003.
- Paving Mosaic Fractal Архивная копия от 10 мая 2012 на Wayback Machine. Базовая информация о структуре Правила 30 от Olivier Schmidt-Chevalier.
- Конференция TED Talk в феврале 2010 Архивная копия от 16 мая 2012 на Wayback Machine. Стивен Вольфрам рассказывает о теории вычислимых знаний, Правиле 30 и многом другом.
- The Wolram Rule 30 Prizes Архивная копия от 4 октября 2019 на Wayback Machine. Несколько вопросов о свойствах правила 30, за решение которых Вольфрам назначил премии.
См. также
правитьПримечания
править- ↑ Stephen Coombes. The Geometry and Pigmentation of Seashells . www.maths.nottingham.ac.uk. University of Nottingham (February 2009). Дата обращения: 10 апреля 2013. Архивировано 18 сентября 2016 года.
- ↑ Wolfram, S. Statistical mechanics of cellular automata (англ.) // Rev. Mod. Phys. : journal. — 1983. — Vol. 55, no. 3. — P. 601—644. — doi:10.1103/RevModPhys.55.601. — .
- ↑ Random Number Generation . Wolfram Mathematica 8 Documentation. Дата обращения: 31 декабря 2011. Архивировано 2 сентября 2013 года.
- ↑ Wolfram, S. (1985). "Cryptography with cellular automata". Proceedings of Advances in Cryptology - CRYPTO '85. Lecture Notes in Computer Science 218, Springer-Verlag. p. 429. (недоступная ссылка). См. также: Meier, Willi; Staffelbach, Othmar (1991). "Analysis of pseudo random sequences generated by cellular automata". Advances in Cryptology: Proc. Workshop on the Theory and Application of Cryptographic Techniques, EUROCRYPT '91. Lecture Notes in Computer Science 547, Springer-Verlag. p. 186.
{{cite conference}}
: Википедия:Обслуживание CS1 (множественные имена: authors list) (ссылка) (недоступная ссылка) - ↑ Cattaneo, Gianpiero; Finelli, Michele; Margara, Luciano. Investigating topological chaos by elementary cellular automata dynamics (англ.) // Theoretical Computer Science : journal. — 2000. — Vol. 244, no. 1—2. — P. 219—241. — doi:10.1016/S0304-3975(98)00345-4.