Cyclone simulates the complete state space for an input finite dynamical system and finds all attractors (steady states and limit cycles), together with statistics about the size of components.
- Developers: Elena Dimitrova, Adam Knapp, Brandilyn Stigler, Michael Stillman
- PI: Reinhard Laubenbacher [email protected]
- coPIs: Brett Tyler, John McDowell, Stefan Hoops
- Developers: Bonny Guang, Madison Brandon, Rustin McNeill, Paul Vines, Franziska Hinkelmann, Seda Arat
Cyclone is available at https://github.com/discretedynamics/cyclone/. See NSF Award 1146819 for details on the project.
A plain text file containing an n-dimensional finite dynamical system f = (f1, ... ,fn), where each fi is a polynomial in Zp[x1, ..., xn] where Zp is the ring Z/pZ. The number of variables n and number of states p can be any positive integer.
#example FDS
NUMBER OF VARIABLES: 4
NUMBER OF STATES: 3
x1 = x2
x2 = x1+x3
x3 = x1*x2 + 1
x4 = (x1+x4)*x3
The first line is a commented line that users can describe their file. The code ignores this line and any others which begin with the comment character #
.
The next two lines are read by the code: the numbers at the ends of the lines can be changed by the user.
The subsequent lines contain the functions determining the finite dynamical system. The function for a variable is represented as variable_name = function_expression
.
- Variable names must begin with a letter but may otherwise be any string without spaces and must not include the built-in arithmetic operator symbols.
- Function expressions can include
+
(addition modulo p),*
(multiplication modulo p),^
(exponentiation),MAX
(maximum of a parenthesized list of variables),MIN
(mimimum of a parenthesized list of variables),NOT
(x+ NOT x = p-1).- Boolean only (p=2):
AND
,OR
or|
,XOR
- All caps or lowercase is accepted for MAX, MIN, NOT, AND, OR, XOR.
Note: When the number of states, p, is not prime, not all possible update functions are expressible by poynomials due to the presence of zero divisors.
simFDS <project-name>.pds
See ** note below.
Cyclone returns the following files by default.
<project-name>-statespace.dot
: a plain-text file containing the state space of the finite dynamical system f. The state space of f is a directed graph with vertex the n-tuples with entries in Fp and edges a --> b iff f(a)=b. The file is formatted as an input to thedot
layout engine in the open source graph visualization software Graphviz.<project-name>-limitcycles.txt
: a plain-text file containing the number of components (basin of attraction + attractor) in the state space graph; the size of each component; and the states that form the limit cycle (attractor).
The following options are useful for large networks.
--summary
returns only the limit cycle file.–-trajectory a1 a2 ... an
returns only produces the portion of the state space beginning at the given initial statea1 a2 ... an
and ending at the associated limit cycle.
To create an image file from the dot file:
dot -Tpng -o <project-name>.png <project-name>-statespace.dot
To build the Cyclone executable simFDS
(on linux or mac):
mkdir -p build
cd build
cmake ..
make
./simFDS
** If the directory continaing simFDS
(in the above instructions, the build directory) has been added to the PATH
environment variable, then simFDS
can be used anywhere. (Documentation on this environment variable can be easily googled.) Otherwise, running simFDS
from the command line will require using the path where simFDS
resides. e.g. When in the build directory, use ./simFDS
.