Package jebl.evolution.trees
Class SimpleTree
- java.lang.Object
-
- jebl.evolution.trees.SimpleTree
-
- All Implemented Interfaces:
Graph,Tree,Attributable
public final class SimpleTree extends java.lang.Object implements Tree
A basic implementation on an unrooted tree.- Version:
- $Id: SimpleTree.java 956 2008-11-30 01:18:20Z rambaut $
- Author:
- Joseph Heled
-
-
Nested Class Summary
-
Nested classes/interfaces inherited from interface jebl.evolution.graphs.Graph
Graph.NoEdgeException, Graph.Utils
-
-
Constructor Summary
Constructors Constructor Description SimpleTree()Tree (to be constructed by subsequent calls).SimpleTree(Tree tree)Duplicate a tree.
-
Method Summary
All Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddEdge(Node node1, Node node2, double length)Add a new edge between two existing (non adjacent yet) nodes.NodecreateExternalNode(Taxon taxon)Creates a new external node with the given taxon.NodecreateInternalNode(java.util.List<Node> adjacencies)Once a SimpleTree has been created, the node stucture can be created by calling createExternalNode and createInternalNode.java.util.List<Node>getAdjacencies(Node node)Returns a list of nodes connected to this node by an edgejava.lang.ObjectgetAttribute(java.lang.String name)java.util.Map<java.lang.String,java.lang.Object>getAttributeMap()Gets the entire attribute map.java.util.Set<java.lang.String>getAttributeNames()EdgegetEdge(Node node1, Node node2)Returns the Edge that connects these two nodesdoublegetEdgeLength(Node node1, Node node2)Returns the length of the edge that connects these two nodesjava.util.Set<Edge>getEdges()java.util.List<Edge>getEdges(Node node)Returns a list of edges connected to this nodejava.util.Set<Edge>getExternalEdges()The set of external edges.java.util.Set<Node>getExternalNodes()java.util.Set<Edge>getInternalEdges()The set of internal edges.java.util.Set<Node>getInternalNodes()NodegetNode(Taxon taxon)java.util.Set<Node>getNodes()java.util.Set<Node>getNodes(int degree)Node[]getNodes(Edge edge)Returns an array of 2 nodes which are the nodes at either end of the edge.java.util.Set<Taxon>getTaxa()TaxongetTaxon(Node node)booleanisExternal(Edge edge)booleanisExternal(Node node)voidremoveAttribute(java.lang.String name)voidrenameTaxa(Taxon from, Taxon to)voidsetAttribute(java.lang.String name, java.lang.Object value)Sets an named attribute for this object.voidsetEdgeLength(Edge edge, double length)Change length of an existing edge.voidsetEdgeLength(Node node1, Node node2, double length)Set edge distance between two adjacent nodes.
-
-
-
Constructor Detail
-
SimpleTree
public SimpleTree()
Tree (to be constructed by subsequent calls).
-
SimpleTree
public SimpleTree(Tree tree)
Duplicate a tree.- Parameters:
tree-
-
-
Method Detail
-
createExternalNode
public Node createExternalNode(Taxon taxon)
Creates a new external node with the given taxon. See createInternalNode for a description of how to use these methods.- Parameters:
taxon- the taxon associated with this node- Returns:
- the created node reference
-
createInternalNode
public Node createInternalNode(java.util.List<Node> adjacencies)
Once a SimpleTree has been created, the node stucture can be created by calling createExternalNode and createInternalNode. First of all createExternalNode is called giving Taxon objects for the external nodes. Then these are put into sets and passed to createInternalNode to create new internal nodes. It is the caller responsibility to insure no cycles are created.- Parameters:
adjacencies- the child nodes of this node- Returns:
- the created node.
-
setEdgeLength
public void setEdgeLength(Node node1, Node node2, double length)
Set edge distance between two adjacent nodes.- Parameters:
node1-node2-length-
-
setEdgeLength
public void setEdgeLength(Edge edge, double length)
Change length of an existing edge.- Parameters:
edge-length-
-
addEdge
public void addEdge(Node node1, Node node2, double length)
Add a new edge between two existing (non adjacent yet) nodes.- Parameters:
node1-node2-length-
-
getEdges
public java.util.List<Edge> getEdges(Node node)
Returns a list of edges connected to this node
-
getAdjacencies
public java.util.List<Node> getAdjacencies(Node node)
Description copied from interface:GraphReturns a list of nodes connected to this node by an edge- Specified by:
getAdjacenciesin interfaceGraph- Parameters:
node-- Returns:
- the set of nodes that are attached by edges to the given node.
-
getEdge
public Edge getEdge(Node node1, Node node2) throws Graph.NoEdgeException
Returns the Edge that connects these two nodes- Specified by:
getEdgein interfaceGraph- Parameters:
node1-node2-- Returns:
- the edge object.
- Throws:
Graph.NoEdgeException- if the nodes are not directly connected by an edge.
-
getExternalNodes
public java.util.Set<Node> getExternalNodes()
- Specified by:
getExternalNodesin interfaceTree- Returns:
- a set of all nodes that have degree 1. These nodes are often refered to as 'tips'.
-
getInternalNodes
public java.util.Set<Node> getInternalNodes()
- Specified by:
getInternalNodesin interfaceTree- Returns:
- a set of all nodes that have degree 2 or more. These nodes are often refered to as internal nodes.
-
getTaxa
public java.util.Set<Taxon> getTaxa()
-
isExternal
public boolean isExternal(Node node)
- Specified by:
isExternalin interfaceTree- Parameters:
node- the node- Returns:
- true if the node is of degree 1.
-
isExternal
public boolean isExternal(Edge edge)
- Parameters:
edge- the edge- Returns:
- true if the edge has a node of degree 1.
-
renameTaxa
public void renameTaxa(Taxon from, Taxon to)
- Specified by:
renameTaxain interfaceTree
-
getEdgeLength
public double getEdgeLength(Node node1, Node node2) throws Graph.NoEdgeException
Description copied from interface:GraphReturns the length of the edge that connects these two nodes- Specified by:
getEdgeLengthin interfaceGraph- Parameters:
node1-node2-- Returns:
- the length of the edge connecting node1 and node2.
- Throws:
Graph.NoEdgeException- if the nodes are not directly connected by an edge.
-
getNodes
public Node[] getNodes(Edge edge)
Returns an array of 2 nodes which are the nodes at either end of the edge.
-
getNodes
public java.util.Set<Node> getNodes()
-
getEdges
public java.util.Set<Edge> getEdges()
-
getNodes
public java.util.Set<Node> getNodes(int degree)
-
getExternalEdges
public java.util.Set<Edge> getExternalEdges()
The set of external edges. This is a pretty inefficient implementation because a new set is constructed each time this is called.- Specified by:
getExternalEdgesin interfaceTree- Returns:
- the set of external edges.
-
getInternalEdges
public java.util.Set<Edge> getInternalEdges()
The set of internal edges. This is a pretty inefficient implementation because a new set is constructed each time this is called.- Specified by:
getInternalEdgesin interfaceTree- Returns:
- the set of internal edges.
-
setAttribute
public void setAttribute(java.lang.String name, java.lang.Object value)Description copied from interface:AttributableSets an named attribute for this object.- Specified by:
setAttributein interfaceAttributable- Parameters:
name- the name of the attribute.value- the new value of the attribute.
-
getAttribute
public java.lang.Object getAttribute(java.lang.String name)
- Specified by:
getAttributein interfaceAttributable- Parameters:
name- the name of the attribute of interest, or null if the attribute doesn't exist.- Returns:
- an object representing the named attributed for this object.
-
removeAttribute
public void removeAttribute(java.lang.String name)
- Specified by:
removeAttributein interfaceAttributable- Parameters:
name- name of attribute to remove
-
getAttributeNames
public java.util.Set<java.lang.String> getAttributeNames()
- Specified by:
getAttributeNamesin interfaceAttributable- Returns:
- an array of the attributeNames that this object has.
-
getAttributeMap
public java.util.Map<java.lang.String,java.lang.Object> getAttributeMap()
Description copied from interface:AttributableGets the entire attribute map.- Specified by:
getAttributeMapin interfaceAttributable- Returns:
- an unmodifiable map
-
-