Package weka.gui.graphvisualizer
Class HierarchicalBCEngine
java.lang.Object
weka.gui.graphvisualizer.HierarchicalBCEngine
- All Implemented Interfaces:
- GraphConstants,- LayoutEngine
This class lays out the vertices of a graph in a hierarchy of vertical
 levels, with a number of nodes in each level. The number of levels is the
 depth of the deepest child reachable from some parent at level 0. It
 implements a layout technique as described by K. Sugiyama, S. Tagawa, and M.
 Toda. in "Methods for visual understanding of hierarchical systems", IEEE
 Transactions on Systems, Man and Cybernetics, SMC-11(2):109-125, Feb. 1981.
 
There have been a few modifications made, however. The crossings function is changed as it was non-linear in time complexity. Furthermore, we don't have any interconnection matrices for each level, instead we just have one big interconnection matrix for the whole graph and a int[][] array which stores the vertices present in each level.
- Version:
- $Revision: 10502 $ - 24 Apr 2003 - Initial version (Ashraf M. Kibriya)
- Author:
- Ashraf M. Kibriya (amk14@cs.waikato.ac.nz)
- 
Field SummaryFields inherited from interface weka.gui.graphvisualizer.GraphConstantsDIRECTED, DOUBLE, NORMAL, PLURAL_DUMMY, REVERSED, SINGULAR_DUMMY
- 
Constructor SummaryConstructorsConstructorDescriptionSimpleConstructor If we want to instantiate the class first, and if information for nodes and edges is not available.HierarchicalBCEngine(ArrayList<GraphNode> nodes, ArrayList<GraphEdge> edges, int nodeWidth, int nodeHeight) Constructor - takes in FastVectors of nodes and edges, and the initial width and height of a nodeHierarchicalBCEngine(ArrayList<GraphNode> nodes, ArrayList<GraphEdge> edges, int nodeWidth, int nodeHeight, boolean edgeConcentration) Constructor - takes in FastVectors of nodes and edges, the initial width and height of a node, and a boolean value to indicate if the edges should be concentrated.
- 
Method SummaryModifier and TypeMethodDescriptionvoidMethod to add a LayoutCompleteEventListenervoidFires a LayoutCompleteEvent.This method returns a handle to the extra controls panel, so that the visualizing class can add it to some of it's own gui panel.getNodes()give access to set of graph nodesReturns a handle to the progressBar of this LayoutEngine.voidThis method does a complete layout of the graph which includes removing cycles, assigning levels to nodes, reducing edge crossings and laying out the vertices horizontally for better visibility.voidphaseIID(int lindex, int[][] levels) See Sugiyama et al.voidphaseIIU(int lindex, int[][] levels) See Sugiyama et al.voidphaseIU(int lindex, int[][] levels) See Sugiyama et al.voidMethod to remove a LayoutCompleteEventListener.voidsetNodesEdges(ArrayList<GraphNode> nodes, ArrayList<GraphEdge> edges) Sets the nodes and edges for this LayoutEngine.voidsetNodeSize(int nodeWidth, int nodeHeight) Sets the size of a node.
- 
Constructor Details- 
HierarchicalBCEnginepublic HierarchicalBCEngine(ArrayList<GraphNode> nodes, ArrayList<GraphEdge> edges, int nodeWidth, int nodeHeight) Constructor - takes in FastVectors of nodes and edges, and the initial width and height of a node
- 
HierarchicalBCEnginepublic HierarchicalBCEngine(ArrayList<GraphNode> nodes, ArrayList<GraphEdge> edges, int nodeWidth, int nodeHeight, boolean edgeConcentration) Constructor - takes in FastVectors of nodes and edges, the initial width and height of a node, and a boolean value to indicate if the edges should be concentrated.- Parameters:
- nodes- - FastVector containing all the nodes
- edges- - FastVector containing all the edges
- nodeWidth- - A node's allowed width
- nodeHeight- - A node's allowed height
- edgeConcentration- - True: if want to concentrate edges, False: otherwise
 
- 
HierarchicalBCEnginepublic HierarchicalBCEngine()SimpleConstructor If we want to instantiate the class first, and if information for nodes and edges is not available. However, we would have to manually provide all the information later on by calling setNodesEdges and setNodeSize methods
 
- 
- 
Method Details- 
getNodesgive access to set of graph nodes- Specified by:
- getNodesin interface- LayoutEngine
 
- 
getControlPanelThis method returns a handle to the extra controls panel, so that the visualizing class can add it to some of it's own gui panel.- Specified by:
- getControlPanelin interface- LayoutEngine
 
- 
getProgressBarReturns a handle to the progressBar of this LayoutEngine.- Specified by:
- getProgressBarin interface- LayoutEngine
 
- 
setNodesEdgesSets the nodes and edges for this LayoutEngine. Must be used if the class created by simple HierarchicalBCEngine() constructor.- Specified by:
- setNodesEdgesin interface- LayoutEngine
- Parameters:
- nodes- - FastVector containing all the nodes
- edges- - FastVector containing all the edges
 
- 
setNodeSizepublic void setNodeSize(int nodeWidth, int nodeHeight) Sets the size of a node. This method must be used if the class created by simple HierarchicalBCEngine() constructor.- Specified by:
- setNodeSizein interface- LayoutEngine
- Parameters:
- nodeWidth- - A node's allowed width
- nodeHeight- - A node's allowed height
 
- 
addLayoutCompleteEventListenerMethod to add a LayoutCompleteEventListener- Specified by:
- addLayoutCompleteEventListenerin interface- LayoutEngine
- Parameters:
- l- - Listener to receive the LayoutCompleteEvent by this class.
 
- 
removeLayoutCompleteEventListenerMethod to remove a LayoutCompleteEventListener.- Specified by:
- removeLayoutCompleteEventListenerin interface- LayoutEngine
- Parameters:
- e- - The LayoutCompleteEventListener to remove.
 
- 
fireLayoutCompleteEventFires a LayoutCompleteEvent.- Specified by:
- fireLayoutCompleteEventin interface- LayoutEngine
- Parameters:
- e- - The LayoutCompleteEvent to fire
 
- 
layoutGraphpublic void layoutGraph()This method does a complete layout of the graph which includes removing cycles, assigning levels to nodes, reducing edge crossings and laying out the vertices horizontally for better visibility. The removing of cycles and assignment of levels is only performed if hasn't been performed earlier or if some layout option has been changed and it is necessary to do so. It is necessary to do so, if the user selects/deselects edge concentration or topdown/bottomup options.The layout is performed in a separate thread and the progress bar of the class is updated for each of the steps as the process continues. - Specified by:
- layoutGraphin interface- LayoutEngine
 
- 
phaseIUpublic void phaseIU(int lindex, int[][] levels) See Sugiyama et al. 1981 (full reference give at top) lindex is the index of the level we want to process. In this method we'll sort the vertices at the level lindex according to their DOWN-barycenters (or row barycenters).
- 
phaseIIDpublic void phaseIID(int lindex, int[][] levels) See Sugiyama et al. 1981 (full reference give at top)
- 
phaseIIUpublic void phaseIIU(int lindex, int[][] levels) See Sugiyama et al. 1981 (full reference give at top)
 
-