Specifying a non-stationary model with time-heterogeneous parameters#

A model is considered time-heterogeneous if rate matrix terms differ between edges on a tree.

In this example, we load and display our sample primate tree, highlighting the edges that will be assigned different rate matrices.

from cogent3 import load_tree
from cogent3 import get_app

tree = load_tree("data/primate_brca1.tree")
fig = tree.get_figure(contemporaneous=True)
fig.style_edges(
    "Human", tip2="Orangutan", outgroup="Galago", line=dict(color="red")
)
fig.show(width=500, height=500)

Specify a distinct rate matrix for the great apes#

As illustrated above, this is done by specifying the names of two “ingroup” tips (their last common ancestor is the ancestor of all edges of interest) and an “outgroup” tip. We can define the clade by Orangutan and one of Human, Chimpanzee or Gorilla. Any tip not a member of the clade outside suffices as an outgroup.

To construct a model with this information, we create a dictionary that we assign to the time_het argument as follows.

time_het = get_app("model",
    "GN",
    tree=tree,
    time_het=[dict(tip_names=["Human", "Orangutan"], outgroup_name="Galago")],
)

The outcome of this setting to model is that the black edges will share one rate matrix, the red edges another. We fit the model to the data.

loader = get_app("load_aligned", format="fasta")
aln = loader("data/primate_brca1.fasta")
result = time_het(aln)

Examining the fitted likelihood function, the rate parameters differ between the edge sets.

result.lf

GN

log-likelihood = -6982.2973

number of free parameters = 33

Edge params
edgeparentlengthA>CA>GA>TC>AC>GC>T
Galagoroot0.17291.00633.78291.03841.72452.32456.3346
HowlerMonroot0.04501.00633.78291.03841.72452.32456.3346
Rhesusedge.30.02141.00633.78291.03841.72452.32456.3346
Orangutanedge.20.00770.21033.50090.20930.90131.35344.9566
Gorillaedge.10.00250.21033.50090.20930.90131.35344.9566
Humanedge.00.00610.21033.50090.20930.90131.35344.9566
Chimpanzeeedge.00.00280.21033.50090.20930.90131.35344.9566
edge.0edge.10.00000.21033.50090.20930.90131.35344.9566
edge.1edge.20.00340.21033.50090.20930.90131.35344.9566
edge.2edge.30.01211.00633.78291.03841.72452.32456.3346
edge.3root0.00761.00633.78291.03841.72452.32456.3346
continuation
G>AG>CG>TT>AT>C
9.01741.24700.76491.45813.5748
9.01741.24700.76491.45813.5748
9.01741.24700.76491.45813.5748
4.62271.11490.00000.33942.9912
4.62271.11490.00000.33942.9912
4.62271.11490.00000.33942.9912
4.62271.11490.00000.33942.9912
4.62271.11490.00000.33942.9912
4.62271.11490.00000.33942.9912
9.01741.24700.76491.45813.5748
9.01741.24700.76491.45813.5748
Motif params
ACGT
0.37570.17420.20950.2406