| Contents | Index |
PhyloTree = seqneighjoin(Distances)
PhyloTree = seqneighjoin(Distances, Method)
PhyloTree = seqneighjoin(Distances, Method, Names)
seqneighjoin(..., 'Reroot', RerootValue)
| Distances | Matrix or vector returned by the seqpdist function. |
| Method | Method to compute the distances between nodes. Enter 'equivar' (default), 'firstorder', or 'average'. |
| Names | Vector of structures with the fields 'Header', 'Name', or a cell array of strings. In all cases the number of elements must equal the number of samples used to generate the pairwise distances in Distances. |
PhyloTree = seqneighjoin(Distances) computes a phylogenetic tree object from Distances, pairwise distances between the species or products, using the neighbor-joining method.
PhyloTree = seqneighjoin(Distances, Method) specifies Method, a method to compute the distances of the new nodes to all other nodes at every iteration. The general expression to calculate the distances between the new node, n, after joining i and j and all other nodes (k), is given by
D(n,k) = a*D(i,k) + (1-a)*D(j,k) - a*D(n,i) - (1-a)*D(n,j)
This expression is guaranteed to find the correct tree with additive data (minimum variance reduction).
Choices for Method are:
| Method | Description |
|---|---|
| 'equivar' (default) | Assumes equal variance and independence of evolutionary distance estimates (a = 1/2). Such as in Studier and Keppler, JMBE (1988). |
| 'firstorder' | Assumes a first-order model of the variances and covariances of evolutionary distance estimates, 'a' is adjusted at every iteration to a value between 0 and 1. Such as in Gascuel, JMBE (1997). |
| 'average' | New distances are the weighted average of previous distances while the branch distances are ignored. D(n,k) = [ D(i,k) + D(j,k) ] /2 As in the original neighbor-joining algorithm by Saitou and Nei, JMBE (1987). |
PhyloTree = seqneighjoin(Distances, Method, Names) passes a list of names (Names) to label the leaf nodes (e.g., species or products) in the phylogenetic tree object.
seqneighjoin(..., 'Reroot', RerootValue),
when RerootValue is false,
excludes rerooting the resulting tree. This is useful for observing
the original linkage order followed by the algorithm. By default seqneighjoin reroots
the resulting tree using the midpoint method.
Build a phylogenetic tree using the neighbor joining method and specifying both a distance-computing method and leaf names.
Create an array of structures representing a multiple alignment of amino acids:
seqs = fastaread('pf00002.fa');Measure the Jukes-Cantor pairwise distances between sequences:
distances = seqpdist(seqs,'method','jukes-cantor','indels','pair');
You will use the output argument distances, a vector containing biological distances between each pair of sequences, as an input argument to seqneighjoin.
Build the phylogenetic tree for the multiple sequence alignment using the neighbor-joining algorithm. Specify the method to compute the distances of the new nodes to all other nodes. Provide leaf names:
phylotree = seqneighjoin(distances,'equivar',seqs)Phylogenetic tree object with 32 leaves (31 branches)
View the phylogenetic tree:
view(phylotree)

[1] Saitou, N., and Nei, M. (1987). The neighbor-joining method: A new method for reconstructing phylogenetic trees. Molecular Biology and Evolution 4(4), 406–425.
[2] Gascuel, O. (1997). BIONJ: An improved version of the NJ algorithm based on a simple model of sequence data. Molecular Biology and Evolution 14 685–695.
[3] Studier, J.A., Keppler, K.J. (1988). A note on the neighbor-joining algorithm of Saitou and Nei. Molecular Biology and Evolution 5(6) 729–731.
cluster | multialign | phytree | plot | reroot | seqlinkage | seqpdist | view

See how to analyze, visualize, and model biological data and systems using MathWorks products.
Get free kit| © 1984-2012- The MathWorks, Inc. - Site Help - Patents - Trademarks - Privacy Policy - Preventing Piracy - RSS |