Skip to content

Package for simulating and displaying chemical reaction networks (CRNs) on a surface.

License

Notifications You must be signed in to change notification settings

DNA-and-Natural-Algorithms-Group/surface_crns

 
 

Repository files navigation

Simulation of Chemical Reaction Networks (CRNs) on a surface

This package is a companion to Clamons, Qian, & Winfree 2020 ("Programming and Simulating Chemical Reaction Networks on a Surface"). It simulates surface Chemical Reaction Networks (surface CRNs), as defined in Qian & Winfree 2014 ("Parallel and Scalable Computation and Spatial Dynamics with DNA-Based Chemical Reaction Networks on a Surface"). A version frozen at the release of the paper will be made available on a paper-release branch, while the master branch will be kept up-to-date with any subsequent bug fixes or improvements.

This package provides:

  • A core simulator for simulating surface CRNs on arbitrary graphs.
  • Models and views for square-grid and hex-grid surface CRNs.
  • A manifest-reading system to simplify setting up new surface CRNs.
  • A pygame-powered GUI for visualizing square-grid and hex-grid surface CRNs.
  • A number of examples of surface CRNs, including examples from the paper and examples of programmatic access to the package's underlying functionality.

If you are using surface_crns on OSX, read the note for you in "Prerequisites".

Prerequisites

The GUI simulator requires pygame and numpy, both of which can be installed with pip.

This simulator is only tested in Python 3. It will likely not run in Python 2.

Important note for OSX users: There is a known problem with Pygame mouse click registration on OSX with certain installations of Python. In Python 3, if you use virtualenv or a Conda installation of Python, Pygame will only register mouse movement when the mouse button is held down. You can fix this by turning off virtualenv or (if you use Conda) by using pythonw instead of python to run your simulations. If, for whatever reason, you cannot do either of these things, make sure to move your mouse during each click, ending the click on whatever button you want to press.

Important note for OSX 10.14 users: The current public stable version of pygame (1.9.6) does not work in OSX 10.14 in some verisons of Python 3. The development version of pygame does work on OSX 10.14. If you are running OSX 10.14 and you don't get a window when you run SurfaceCRNQueueSimulator, try downloading the pygame repository at https://github.com/pygame/pygame, navigate into the downloaded folder, and run python setup.py install.

Installation

Install with the following (probably requires sudo): pip install surface_crns

To update, run (also with superuser privilege): pip install --upgrade --no-deps surface_crns

If you are using OSX and you get a mysterious error while installing surface_crns or pygame, you may need to install several SDL libraries used by pygame. Install them with brew (https://brew.sh/) with the command:

brew install sdl sdl_image sdl_mixer sdl_ttf portmidi

What's a surface CRN?

In brief, a surface CRN is a stochastic chemical reaction network where individual molecules are tethered to fixed positions on a surface such that they can only interact with neighbors; stated another way, a surface CRN is an asynchronous cellular automata with transition rules that resemble those of unimolecular and bimolecular chemical reactions.

A surface CRN consists of a number of sites with states on an arbitrary lattice (we usually use a square grid, but a surface CRN could use any graph as its lattice), along with transition rules of the form A -> B or A + B -> C + D, with a real-valued reaction rate for each transition rule. States change stochastically according to the transition rules for the surface CRN, with expected time specified by the reaction rate for each reaction.

For example, a site with state A can undergo A -> B to instantaneously switch to state B.

Bimolecular reactions (of the form A + B -> C + D) can occur only if both of the species before the arrow are present and next to each other on the lattice (note that there is no "directionality" inherent to the surface, so an A next to a B is equivalent to a B next to an A). When a bimolecular reaction occurs, the first reactant instantaneously becomes the first product, and the second reactant simultaneously and becomes the second product, so the states A B would become C D (or, equivalently, B A would become D C).

What can you do with a surface CRN? Some examples are shown in the paper, and also in this earlier paper by Qian and Winfree; See what you can make!

How do I use the simulator?

The fastest way to start using the simulator is to use our hosted version of the simulator at http://centrosome.caltech.edu/Surface_CRN_Simulator/srv/.

This package lets you run simulations locally, with more control and a less cumbersome interface. First, install this package as described under "Installation". This will install an executable script SurfaceCRNQueueSimulator, which you can run directly from the command line with

SurfaceCRNQueueSimulator -m <manifest_file>

where <manifest_file> is the name of a valid manifest file (see below). We have provided a number of example manifests in the examples folder, and you can get more from the online simulator. Please note that some of these manifests use information from other files in the examples folder. The easiest way to use these examples is to clone this repository and copy the entire examples folder.

You can also run the simulator from a Python script. If you are having difficulty running SurfaceCRNQueueSimulator directly, this is the next thing you should try. To run a surface CRN specified in a file "example_manifest.txt", you would run (in your Python terminal or script)

from surface_crns import SurfaceCRNQueueSimulator
SurfaceCRNQueueSimulator.simulate_surface_crn("example_manifest.txt")

If you are one of the users affected by the Pygame mouse click registration bug mentioned in "Prerequisites", you can run SurfaceCRNQueueSimulator with pythonw. First, find the full name and location of SurfaceCRNQueueSimulator on your machine by running which SurfaceCRNQueueSimulator. Then run pythonw <simulator_name> -m <manifest_file>, where <simulator_name> is the output of the which command you ran. You'll also have to use pythonw to run any script you run that uses SurfaceCRNQueueSimulator.

What is a "manifest file"?

A manifest file is a text file that defines a surface CRN. It includes the rules of the surface CRN, an initial condition, a colormap to control how the surface CRN will be displayed, and a number of run options.

How do I write a manifest file?

You can find manifest files for several example surface CRNs in the "examples" folder of this repository. There are also a number of examples available at http://www.dna.caltech.edu/Surface_CRN_Simulator/srv/.

A surface chemical reaction network (sCRN) on a square grid can be specified by a manifest file consisting of four parts:

  • Transition rules
  • Initial state
  • Colormap
  • General Settings

Any text on a line after a '#' will be treated as a comment and ignored.

Transition Rules

The section of a manifest specifying transition rules begins with the line "!START_TRANSITION_RULES" and ends with the line "!END_TRANSITION_RULES" (no quotation marks). A single transition rule is specified by a line of the form

(RATE) NAME1 -> NAME2

or

(RATE) NAME1 + NAME2 -> NAME3 + NAME4

where "RATE" is a (nonnegative) number designating the reaction rate of the transition rule, and NAME1, NAME2, NAME3, and NAME4 are alphanumeric species identifiers. Species identifiers may contain letters, numbers, commas, and underscores, but not other punctuation or whitespace. For example, a rule that species X1 and Y1 react to form species X2 and Y2 with rate 10 (in arbitrary units of 1/time) would be specified with:

(10) X1 + Y1 -> X2 + Y2

Rates may be placed anywhere in a transition rule statement except inside an identifier or the "->" token. For example, the following transition rules are all valid:

(10) X + Y -> A + B
X + Y ->(10) A + B
X + Y -> A + B (10)

Initial state

The section of a manifest specifying the initial state of the surface begins with the line "!START_INIT_STATE" and ends with the line "!END_INIT_STATE". An initial state is specified in a comma- or whitespace-separated format, with rows separated by newlines and columns are separated by either whitespace or commas (either is acceptable).

The contents of each cell in the grid are specified just as species in the transition rule section. The name used in the initial state section must exactly match the name used in the transition rule section, or transition rules will not be applied to that position.

Colormap

The colormap section of the manifest begins with the line "!START_COLORMAP" and ends with the line "!END_COLORMAP". The colormap determines the colors that will be used to represent each species, and can be used to group multiple species to be displayed as one color. The colormap is optional; if no colormap is specified, then colors will be assigned automatically and each species will be labeled with its species name.

A single species' color can be specified with a line of the form

NAME: (R, G, B)

where "NAME" is the name of the species (of the same format used to specify species names in the transition rules and initial state sections) and "R", "G", and "B" are integers between 0 and 255 (inclusive) specifying the red, green, and blue components of the specified color. For instance, to make species "X1" display as black, one would write

X1: (0, 0, 0)

and to make species "Y1" display as vibrant red, one would write

Y1: (255, 0, 0)

Multiple species can also be grouped to be displayed with the same color and given a single display name using a statement of the form

{CLASS} NAME1, NAME2,...: (R, G, B)

where "CLASS" is the (optional) name under which the species should be displayed, "NAME1, NAME2,..." is a comma-separated list of species names of any length, and "R", "G", and "B" are as above. For instance, to display all of the species X1, X2, X3, and X4 as red and all of the species Y1, Y2, Y3, and Y4 as green, one would write

{X} X1, X2, X3, X4: (255, 0, 0)
{Y} Y1, Y2, Y3, Y4: (0, 255, 0)

General Settings

Any line not in a transition rule, initial state, or colormap block is interpreted as a general setting. General settings take the form

SETTING = VALUE

with the obvious meanings. Useful settings to know are:

  • speedup_factor (default 1): A nonnegative real number dictating the speed of simulation playback. Larger numbers mean faster playback, up to the processing limits of pygame and of the simulator.
  • fps (default 30): A nonnegative real integer that controls the frame rate of the simulation playback. Higher fps will produce smoother output, but will take more time, RAM, and disk space to run. Lower fps may be choppy, but cuts down on the number of frames that need to be drawn (and, on the web simulator, stored).
  • debug (default False): If True, the simulator will spew out debugging info when run. You probably want this set to False.
  • rng_seed (default None): Integer specifying the random number seed used by the simulation. Set this value to a positive integer to make simulations reproducible.
  • max_duration (default 1000000): A nonnegative number specifying the maximum length of simulation in arbitrary time units (the same arbitrary time units specified by transition rule reaction rates).
  • node_display (default color): Determines whether the state of each position on the grid (node) is overlaid, in text, on that node. Set to "text" to overlay text, or "color" to only show node color.
  • pixels_per_node (default 5): Determines the size of a node, in pixels.
  • wrap (default False): Iff True, grid connections wrap top-to-bottom and left-to-right (and vice versa).
  • geometry (default square): Toggles surface geometry to either a square grid (default, square) or a hex grid (hex). If hex, the initial condition will still be given as a rectangular grid, with every other line shifted by a half-hex.

Including Files

It's often helpful to store parts of a manifest file separately. For example, you may wish to share the same transition rules and/or colormap settings across a number of simulations with separate manifests.

To do this, put whatever you want to store separately in its own document (here, some_other_file.txt), and include it in the manifest with

!INCLUDE some_other_file.txt

The !INCLUDE line will be replaced with the contents of some_other_text_file.txt. If you'd like see more examples of the use of the INCLUDE statement, check out the chapter 3 paper examples.

Acknowledgements

This package uses the pygbutton package by Al Sweigart (https://github.com/asweigart/pygbutton), as well as the random_color function made by adews (https://gist.github.com/adewes/5884820.). Thanks to both authors!

References

This packages is a companion to this paper: Clamons S., Qian L., Winfree E. (2020) Programming and Simulating Chemical Reaction Networks on a Surface. In: Journal of the Royal Society Interface, vol 17, issue 166. Royal Society. https://doi.org/10.1098/rsif.2019.0790

The original formulation of surface CRNs: Qian L., Winfree E. (2014) Parallel and Scalable Computation and Spatial Dynamics with DNA-Based Chemical Reaction Networks on a Surface. In: Murata S., Kobayashi S. (eds) DNA Computing and Molecular Programming. DNA 2014. Lecture Notes in Computer Science, vol 8727. Springer, Cham. https://doi.org/10.1007/978-3-319-11295-4_8

About

Package for simulating and displaying chemical reaction networks (CRNs) on a surface.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 100.0%