skbio.tree.TreeNode.lca#
- TreeNode.lca(nodes=None)[source]#
Find the lowest common ancestor of a list of nodes.
Alias:
lowest_common_ancestor
- Parameters:
- nodesiterable of TreeNode or str
Instances or names of the nodes of interest.
Changed in version 0.6.3: Renamed from
tipnames
. The old name is kept as an alias but is deprecated.
- Returns:
- TreeNode
The lowest common ancestor of the nodes.
- Raises:
- MissingNodeError
If some nodes cannot be found in the tree.
Notes
Both tips and internal nodes may be provided in
nodes
. If internal node names are provided, it is the user’s responsibility to ensure that they are unique in the tree.This method considers the entire tree rather than the subtree below self. Therefore, if some nodes are not descendants of self, the LCA of nodes will be ancestral to self.
Examples
>>> from skbio import TreeNode >>> tree = TreeNode.read(["((a,b)c,(d,e)f)root;"]) >>> nodes = [tree.find('a'), tree.find('b')] >>> lca = tree.lca(nodes) >>> print(lca.name) c >>> nodes = [tree.find('a'), tree.find('e')] >>> lca = tree.lca(nodes) # lca is an alias for convience >>> print(lca.name) root