JavaScript - Клеточный автомат
Материал из Department of Theoretical and Applied Mechanics
Версия от 22:50, 12 апреля 2014; Денис (обсуждение | вклад)
Кафедра ТМ > Программирование > Интернет > JavaScript > Клеточный автомат
Данная страница содержит ссылки на различные версии постепенно развивающейся реализации клеточного автомата на языке JavaScript, а также описание каждой версии.
CelAut v1
Базовая реализация двухмерного клеточного автомата.
- Используется окрестность Мура первого порядка - состояние каждой клетки зависит от восьми клеток вокруг.
- Установлены периодические граничные условия - клетка, находящаяся на краю поля взаимодействует с клетками на противоположном краю. По сути, получается поверхность тора.
- Правила работы автомата задаются геномами L и B. Размер генома равен количеству различных вариантов состояний клеток в окрестности рассматриваемой клетки. В окрестности Мура возможно 9 вариантов - от 0 до 8 живых клеток вокруг нашей клетки.
- L описывает поведение живой клетки на следующем шаге. Например, геном L:110000000 означает, что клетка выживет, если рядом с ней будет находиться 0 или 1 живых клеток.
- B описывает, зародится ли жизнь в неживой клетке на следующем шаге. Например, геном B:001000000 означает, что в неживой клетке зародится жизнь, если рядом будет находиться 2 живые клетки.
- Добавлена кнопка паузы для остановки/запуска клеточного автомата.
- Поле клеточного автомата генерируется случайным образом при запуске автомата.
Примечание: При использовании геномов L:001100000 и B:000100000 получается классическая игра "Жизнь" Джона Конвея.
CelAut v2
- Добавлена возможность добавлять живые клетки левой клавишей мыши и убирать правой.
- Добавлена кнопка "Следующий шаг".
- В коде добавлены функции управления работой автомата.