Efficiently simulating multi-type birth-death processes via forward-equivalent parameter mapping
The simulations and plots are produced by the jupyter notebooks in the notebooks
directory. These should be run in the following order:
- Run all cells in
efficiency.ipynb
in order to run all simulations. It will read output to adata
sub-directory provided thesave_to_file
global varialbe and the"save_tree"
key in the respectivesim_spec
are set toTrue
. - After this, any of the three remaining notebooks can be run. These will create output images in a
fig
sub-directory.distribution_tests.ipynb
: This creates histograms comparing several tree statistics between the full and forward-equivalent simulations.timing_plots.ipynb
: This creates plots comparing the run-time of the full and forward-equivalent simulations across three model specifications.draw_tree.ipynb
: This draws a tree generated by the huge population simulation specification.
These modules are used by the jupyter notebooks.
modulators.py
: Defines theFEModulator
class. AnFEModulator
object is initialized by a specification of the full model and sampling rates, and computes and stores internal data to allow simulation-time access to forward-equivalent model parameters.my_bdms.py
: This module contains three classes:DiscreteProcess
: This sub-classespoisson.Process
and can be used bybdms
for simulation from a constant-rate (birth, death, or mutation) process taking on a finite phenotype space.CustomProcess
: This sub-classespoisson.Process
and allows and user provided time- and state-dependent rates. In our code, we use this class to store birth, death, and mutation rates for the forward-equivalent model. theFEModulator
class provides theCustomProcess
initializer with the appropriate time- and state-dependent rate functions.CustomMutator
: This sub-classesmutators.Mutator
. It is initialized with anFEModulator
object, which is then used to carry out time- and state-dependent mutation transitions according the the forward-equivalent model.
utils.py
: This exports some utility functions, as well functions to compute all the tree statistics used for the distribution tests (indistribution_tests.ipynb
).