US 7605813 B2
A treemap visualization system can include a treemap configured to visualize a set of nodes. The treemap visualization system also can include an event handler programmed to process a proximity event associated with a specific portion of the treemap. The event handler can process the proximity event by visually coupling selected nodes which are inter-related to a node associated with the proximity event. The system further can include logic for displaying a direction for each inter-relationship between the selected nodes and the node associated with the proximity event. In this regard, the proximity event can include a mouse-over event, a mouse-click event, and a keyboard selection event.
1. A method, within a treemap visualization hardware system, for presenting inter-related nodes in a treemap, the treemap comprising hierarchical information to a rectangular 2-D display in a space-filling manner in which the entirely of a designated display space is utilized, the method comprising the steps of:
detecting, by the treemap visualization hardware system, a proximity event about a representation for a node in the treemap;
determining through said representation at least one inter-related node; and,
highlighting said nodes and drawing a linkage in said treemap between said nodes.
2. The method of
determining a directionality for said inter-related node; and,
visually indicating said directionality in said treemap.
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
8. The method of
9. The method of
10. The method of
11. A treemap, the treemap comprising hierarchical information to a rectangular 2-D display in a space-filling manner in which the entirely of a designated display space is utilized, visualization hardware system comprising:
a treemap configured to visualize a set of nodes; and a processor including an event handler programmed to process a proximity event associated with a specific portion of said treemap by visually coupling selected nodes which are interrelated to a node associated with said proximity event.
12. The system of
13. The system of
14. A machine readable storage having stored thereon a computer program for presenting inter-related nodes in a treemap, the treemap comprising hierarchical information to a rectangular 2-D display in a space-filling manner in which the entirely of a designated display space is utilized, the computer program comprising a routine set of instructions for causing the machine to perform the steps of:
detecting a proximity event about a representation for a node in the treemap;
determining through said representation at least one inter-related node; and, highlighting said nodes and drawing a linkage in said treemap between said nodes.
15. The machine readable storage of
determining a directionality for said inter-related node; and,
visually indicating said directionality in said treemap.
16. The machine readable storage of
17. The machine readable storage of
18. The machine readable storage of
19. The machine readable storage of
20. The machine readable storage of
21. The machine readable storage of
22. The machine readable storage of
23. The machine readable storage of
1. Statement of the Technical Field
The present invention relates to the field of data visualization and more particularly, to tree-map visualization.
2. Description of the Related Art
As computer technology advances, computing systems have undertaken the management and processing of even larger data systems. With data systems ranging from massive standalone databases to vast distributed networks, oftentimes the limiting factor in analyzing the state of a given system rests not with computing resources, but with the human operator. Specifically, though the computing system may aggregate vast quantities of data in near real-time, in the end, a human being must visualize the compilation of data to draw effective conclusions from the visualization. Yet, the ability of the end user to digest compiled information varies inversely with the amount of data presented to the end user. Where the amount of compiled data becomes excessive, it can be nearly impossible for a human being to adequately analyze the data.
In an effort to address the foregoing difficulties, tree-map visualization methods have been developed. Initially proposed by Brian Johnson and Ben Shneiderman in the seminal paper, Johnson et al., Tree-Maps: A Space-Filling Approach to the Visualization of Hierarchical Information Structures, Dept. of Computer Science & Human-interaction Laboratory (University of Maryland June 1991), tree-map visualization techniques map “hierarchical information to a rectangular 2-D display in a space-filling manner” in which the entirety of a designated display space is utilized. Additionally, “[i]nteractive control allows users to specify the presentation of both structural (depth bounds, etc.) and content (display properties such as color mappings) information.”
Notably, tree-map visualization techniques can be compared in a contrasting manner to traditional static methods of displaying hierarchically structured information. According to conventional static methods, a substantial portion of hierarchical information can be hidden from user view to accommodate the view of the hierarchy itself. Alternatively, the entire hierarchy can be visually represented, albeit vast amounts of display space can be obscured, hence wasted simply to accommodate the structure without regard to the hierarchical data in the hierarchy itself.
In the tree-map visualization technique, however, sections of the hierarchy containing more important information can be allocated more display space while portions of the hierarchy which are deemed less important to the specific task at hand can be allocated less space. More particularly, in operation tree-maps partition the display space into a collection of rectangular bounding boxes representing the tree structure. The drawing of nodes within the bounding boxes can be entirely dependent on the content of the nodes, and can be interactively controlled. Since the display size is user controlled, the drawing size of each node varies inversely with the size of the tree, for instance the number of nodes. Thus, trees having many nodes can be displayed and manipulated in a fixed display space.
To date, the tree-map visualization technique has been limited to displaying strictly hierarchical data. This is a significant limitation that impedes the usefulness of the tree-map in many circumstances. For example, where a tree-map is used to visualize a set of computing resources which are interconnected to provide business value in a network, an observer can view the individual components of the network, but the relationship will not be as apparent. Specifically, though the status of any particular component in the tree-map can be displayed when a pointing device falls within proximity to the representation of the component in the tree-map, the relationship between the component and other components represented in the tree-map cannot be so readily recognized.
Lacking an awareness of the relationship of node representations in a tree-map can impede the “big picture” analysis of the overall system represented by the tree-map. For example, where in the example of computing resources a client node representation indicates a failure status, it will not be apparent that a related server also may have failed. Of course, where the server managing the client also has failed, it is likely that the server has caused the failure of the client. Yet, the reality of the circumstance cannot be ascertained from the tree-map representation of the computing system incorporating both the client and the server.
The present invention is a system, method and apparatus for presenting inter-relationships in a tree-map. The method can include detecting a proximity event about a representation for a node in the tree-map. The method further can include the step of determining through the representation at least one inter-related node. Finally, the nodes can be highlighted and a linkage can be drawn in the tree-map between the nodes. Importantly, in a preferred aspect of the invention, a directionality for the inter-related node can be determined and the directionality can be visually indicated in the tree-map. To that end, the step of visually indicating can include drawing the linkage with arrowheads to indicate the directionality.
The detecting step can include the step of receiving a mouse-over event in an event handler for the tree-map. Alternatively, the detecting step can include the step of receiving a mouse-over event in an event handler for the representation about which the proximity event is detected. As yet a further alternative, the detecting step can include the step of receiving a mouse-click event in an event handler for the tree-map. Finally, the detecting step can include the step of receiving a mouse-click event in an event handler for the representation about which the proximity event is detected. Importantly, each of the detecting, determining, highlighting and drawings steps can be repeated for a selected group of nodes determined to be inter-related to the node for which a proximity event has been detected. Furthermore, the repeating step can be limited to those nodes which are within a specified number of generations from the node for which the proximity event has been detected.
A tree-map visualization system can include a tree-map configured to visualize a set of nodes. The tree-map visualization system also can include an event handler programmed to process a proximity event associated with a specific portion of the tree-map. The event handler can process the proximity event by visually coupling selected nodes which are inter-related to a node associated with the proximity event. The system further can include logic for displaying a direction for each inter-relationship between the selected nodes and the node associated with the proximity event. In this regard, the proximity event can include a mouse-over event, a mouse-click event, and a keyboard selection event.
There are shown in the drawings embodiments which are presently preferred, it being understood, however, that the invention is not limited to the precise arrangements and instrumentalities shown, wherein:
The present invention is a system, method and apparatus for displaying aribtrary relationships in a tree-map visualization. Whenever a node in the tree-map receives interest, such as when a mouse pointer passes in proximity to the node of interest, all other nodes with which it has inter-connected relationships will be highlighted, and lines drawn between them conveying the direction of the relationship. In this way, the inter-relationship between the node of interest and other nodes in the tree-map can be visually recognized by one observing the tree-map of the present invention.
In the present invention, however, where a nested node such as the node 160 is inter-related to other nodes in the tree-map 100, such as the nodes 170A, 170B, one viewing the tree-map 100 can recognize the inter-relationship through the visualization of such inter-relationship in the tree-map. If the data behind the tree-map 100 has a small number of inter-relationships, all of the inter-relationships could be visualized at once within the tree-map 100. If, however the number of inter-relationships between nodes exceeds some threshold, the system can interactively visualize only selected ones of the inter-relationships extending from a selected node when the user expresses interest in that node, for example by mouse proximity. More particularly, as a mouse pointer 180 passes within proximity to the node 160, a call-out box 190 not only can be overlain about the node 160, but also the directly related nodes 170A, 170B can be highlighted within their respective parent nodes 130, 150 and connected to the node 160.
In a preferred aspect of the invention, the visual connection between the nodes 170A, 170B and the node 160 can indicate the directionality of the relationship. That is, it can be determined whether the node 160 refers only to the nodes 170A, 170B, the nodes 170A, 170B refer only to the node 160, or whether the nodes 160, 170A, 170B refer to each other. Furthermore, though not illustrated specifically in
Importantly, the skilled artisan will recognize that the treemap visualization system, method and apparatus of the invention is not merely limited to a first order relationship between the subject node 160 and its related nodes 170. Rather, additional levels of inter-relationships can be visually presented, as well. In this regard, those nodes which are inter-related with the related nodes 170 also can be visually coupled to the nodes 170 such as the node 175 in the examplary illustration of
The system further can include an event handler 250 programmed to process operating system events received through a user interface 260 to the treemap 100. Specifically, operating system events such as mouse movements, keyboard strikes and mouse clicks can be received in the user interface 260 and routed to the event handler 250. The event handler 250 can determine when the received operating system event should be interpreted as a request to identify an underlying node in the treemap 100. To that end, the operating system event can range from a simple mouse click upon a portion of the treemap corresponding to the node, to a mouse-over event in which the mouse pointer passes over the portion of the treemap corresponding to node.
In any case, responsive to the receipt of such an event, the identity of the underlying node associated with the portion of the treemap 100 can be presented through the user interface 260. For instance, a call-out box can be displayed in a similar manner to a tool-tip in which the identity of the node and ancillary data can be displayed such as the status of the node. Significantly, in addition to displaying the call-out box, the treemap 100 can be searched for inter-related ones of the nodes 210 based upon the reference 220 to inter-related nodes contained within the selected node. For each found node, a visual linkage can be interactively presented in the treemap 100 to indicate not only the existence of the inter-relationship, but also the nature of the inter-relationship. As such, arrows at one or both ends of the linkage can indicate the directionality of the inter-relationship. Moreover, the coloring of the arrows, the linkage or both further can indicate the nature of the inter-relationship.
Otherwise, if references are identified with the underlying node in decision block 330A, in block 340 the first referenced node can be loaded and the process of blocks 320 through 340 can be called recursively by reference both to the current node and the referenced node. Notably, the process of blocks 320 through 340 can be repeated in a recursive manner until a terminating node is identified as the current node. In that case, in block 370 the directionality between the terminating nodes and its referring node can be determined by examining the internal representation of their relationships to see if the current node refers to the referenced node, if the referenced node refers to the current node, or if both refer to each other.
In any case, in block 380, the current node can be highlighted as can the referencing node and a connection can be drawn between the two with arrowheads indicating the directionality. In block 400, the process can return. Notably, the process of blocks 320 through 340 can be repeated for each referenced node in a current node as will be apparent from blocks 340 and 360. Once no more references remain to be analyzed and processed as determined by the decision block 350, the visual coupling can be drawn within the treemap and the recursive process can unwind further until the root node under study has been reached. In that event, the final coupling can be drawn and the process can terminate in block 400.
Significantly, it will be apparent to the skilled artisan that the process shown in
The present invention can be realized in hardware, software, or a combination of hardware and software. An implementation of the method and system of the present invention can be realized in a centralized fashion in one computer system, or in a distributed fashion where different elements are spread across several interconnected computer systems. Any kind of computer system, or other apparatus adapted for carrying out the methods described herein, is suited to perform the functions described herein.
A typical combination of hardware and software could be a general purpose computer system with a computer program that, when being loaded and executed, controls the computer system such that it carries out the methods described herein. The present invention can also be embedded in a computer program product, which comprises all the features enabling the implementation of the methods described herein, and which, when loaded in a computer system is able to carry out these methods. Finally, the user interface of the computer program product can be a user interface expressed through a content browser.
Computer program or application in the present context means any expression, in any language, code or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following a) conversion to another language, code or notation; b) reproduction in a different material form. Significantly, this invention can be embodied in other specific forms without departing from the spirit or essential attributes thereof, and accordingly, reference should be had to the following claims, rather than to the foregoing specification, as indicating the scope of the invention.