Reversible Cellular Automata simulator in HTML5 + Java Script.
The Simulator is a cross-platform web (html5+js) application for exploring reversible cellular automata with Margouls neighborhood. To start using, open the index.html file. The interface is fairly standard for the applicaitons of such kind.
See it here: http://dmishin.github.io/js-revca/index.html
Some explanations on Reversible Cellular Automata: http://dmishin.blogspot.ru/2013/10/reversible-cellular-automata.html
The applicaiton simulates closed thoroidal field with 2 possble cell states: ON and OFF. Field size Is only limited by the size and performance of your computer, but 1024x1024 is close to the upper reasonable limit. Some efforts were put into improving performance of the Simulator, allowing to simulate medium-sized fields for millions of generations in reasonable time.
Besides the basic field editing and simulation, the application offers some advanced features:
- Pattern analyzer: automatically detect type (oscillator / spaceship / neither), period and canonical form of the pattern.
- Rule analyzer: automatically detect many properties of the given block transition function, encoded by the table of 16 integers.
- Spaceship catcher: catch, analyze and add to the library escaping spaceships. Useful for automatic search for the spaceships.
- GIF recorder: record field in the GIF animation.
- Library: store figures collection in the local library (Requires Web Storage support in browser).
- Load from URL: load simulation parameters, including field state, from the URL arguments.
Most of the code is written in CoffeeScript.
To build minified code, following NPM tools are required:
- coffee-script: compile coffescript code
- browserify: prepare application code for using in browser
- uglify-js: minification of the JS
- mocha: required for running tests
These tools are not included, and must be installed separately. Additionally, GNU Make is required, because build system uses it.
Build system for this applicaiton uses GNU Make. To compile app using this system, first run:
$ coffee configure.coffee
After modifying files, you only need to run
make, configure is only needed after adding new files.
Alternatively, if you don't want to bother with this idiosyncratic build ssytem, you can compile everythign manually:
$ coffee -o scripts scripts-src $ browserify scripts/application.js -o scripts/bundle.js $ uglifyjs --screw-ie8 scripts/bundle.js > scripts/minified.js
To run application, open index.html. You can skip the last (minification) step, if replace "minified.js" with "bundle.js" in the index.html.
Code for GIF generation is based on: https://github.com/antimatter15/jsgif
Well, let's say MIT?
Single Rotation Rule SVG Demo
Following parameters can be controlled via URL arguments:
- Animation speed: argument "speed". Default is 0.1
- Animation contents: argument "quick". Possible values are 0 and 1, default is 0.
- Initial pattern, in the RLE format: "rle".
- Initial position of the pattern: arguments "x", "y"
- Color palette for coloring cells. Must be ";"-separated list of the valid SVG colors.
Simulation of the orthogonal c/14 spaceship:
.##..#.# ....##.. #....#..
Its RLE code is:
Or in the Simulator.