Neural Cellular Automata (NCA) are a class of models capable of learning local interactions that give a desired emergent behaviour. Inspired by and based on the work of Mortvinstev et al: https://distill.pub/2020/growing-ca/ , this work extends their NCA framework to learn local rules that yield a time series of images, rather than forming a stable stationary structure. This extension allows for modelling dynamical emergent behaviour, and can reproduce the behaviour of classic PDEs (heat, reaction diffusion). The code in this repository was used to produce results in this paper: https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1011589
- This code is no longer in development, but is kept for reproducability of results in https://journals.plos.org/ploscompbiol/article?id=10.1371/journal.pcbi.1011589 .
- Moving forward, a more flexible and powerful version based on JAX is included in https://github.com/AlexDR1998/Differentiable-Patterning
- tensorflow 2.13.0
- tensorboard 2.13.0
- numpy 1.24.4
- scipy 1.9.0
- scikit-image 0.19.1
- tqdm 4.64.0
- matplotlib 3.7.2
The code is structured as followed.
- NCA code (Tensorflow version)
- NCA/NCA_class.py contains the actual NCA model wrapped in a class for convenience, with saving/loading functionality.
- NCA/trainer/ contains all the code for fitting NCA to data:
- NCA/trainer/NCA_trainer.py includes the basic NCA_Trainer class for fitting an NCA to data
- NCA/trainer/NCA_PDE_trainer.py includes a subclass of NCA_Trainer that is tweaked to train NCA to PDE trajectories
- NCA/trainer/NCA_IC_trainer.py includes a subclass of NCA_Trainer that optimises initial conditions (while keeping NCA model parameters fixed) to explore stability
- NCA/trainer/NCA_trainer_stem_cells.py includes a subclass of NCA_Trainer that is tweaked to train on specific biological data
- NCA/trainer/NCA_train_utils.py includes functions for sweeping through training hyperparameters
- NCA/trainer/NCA_loss_functions.py includes definitions of all the different loss functions explored
- NCA/NCA_utils.py contains a lot of helper functions, mainly file i.o. and stuff that should have been in tensorflow i.e. periodic padding.
- Other non NCA stuff
- NCA/PDE_solver.py contains the PDE_Solver class that performs finite difference / euler numerical solutions of PDEs for the NCA to be trained on
- NCA/GOL_solver.py contains the GOL_Solver class that simulates conway's game of life, as a test to see if the NCA can recover that behaviour.