Tuesday, October 11, 2011

Simulating a set number of changes in a discrete character on the tree using sim.history()

An R phylogenetics user recently queried as to whether it was possible to simulate random character evolution with a fixed number of changes - say 2, 5 or 10 - in a binary character on the tree. In fact, this can be done using the function sim.history() in the latest version of "phytools" (not yet available on CRAN, but downloadable from my website here).

I submitted the following code fragment:

nchanges<-5 # desired number of changes
ntrees<-100 # desired number of trees
ntaxa<-100 # desired number of taxa
require(phytools); require(geiger) # required packages
for(i in 1:ntrees){
  # simulate a stochastic B-D tree using birthdeath.tree
  # compute the rate that results in (on average) nchanges changes
  # simulate a stochastic history
  # loop until desired number of changes
  # for fun, plot the history
# tip states for the kth tree are in mtrees[[k]]$states

This is for a desired count of 5 changes on the tree. The way it works is by first computing the substitution rate that will produce an expected number of changes of 5 (in this case); and then by simulating repeatedly with this rate, retaining only those simulations that result in 5 changes on the tree.

The result is stored in a "simmap" style tree; with tip states in the list component $states.

Below is an example of a tree simulated using this method, but with nchanges=10 and plotSimmap(...,pts=0,fsize=0.7):

No comments:

Post a Comment

Note: due to the very large amount of spam, all comments are now automatically submitted for moderation.