The invention is explained in further detail, and by way of example, with reference to the accompanying drawings wherein:
The following are descriptions of illustrative embodiments that when taken in conjunction with the following drawings will demonstrate the above noted features and advantages, as well as further ones. In the following description, for purposes of explanation rather than limitation, illustrative details are set forth such as architecture, interfaces, techniques, network elements, etc. However, it will be apparent to those of ordinary skill in the art that other embodiments that depart from these details would still be understood to be within the scope of the appended claims. Moreover, for the purpose of clarity, detailed descriptions of well known devices, circuits, modeling tools, analysis techniques and methods are omitted so as not to obscure the description of the present system.
It should be expressly understood that the drawings are included for illustrative purposes and do not represent the scope of the present system. In the accompanying drawings, like reference numbers in different drawings may designate similar elements. In addition, a first portion of a reference number may designate a figure wherein the reference number is provided.
The system and method described herein address problems in prior art systems. In accordance with the present system, modeling tools and information are provided within a visual environment including a user interface (UI), such as a graphical user interface (GUI). The GUI may be provided by an application running on a computer. The visual environment is displayed by the computer on a display device and a user is typically provided with an input device to influence events or images depicted on the display. GUI's present visual images which describe various visual metaphors of an operating system, an application, etc., that may be implemented on the computer.
The user typically moves a user-controlled object, such as a cursor or pointer, across a computer screen and onto other displayed objects or screen regions, and then inputs a command to execute a given selection or operation. Other applications or visual environments also may provide user-controlled objects such as a cursor for selection and manipulation of depicted objects in either of a two-dimensional or three-dimensional space.
The user interaction with and manipulation of the computer environment is achieved using any of a variety of types of human-computer interface devices that are connected to the computer controlling the displayed environment. A common interface device for GUI's is a mouse, trackball, keyboard, etc. For example, a mouse may be moved by a user in a planar workspace to move an object such as a cursor on a two-dimensional display screen in a direct mapping between the position of the user manipulation and the position of the cursor. This is typically known as position control, where the motion of the object directly correlates to motion of the user manipulation.
An example of such a GUI in accordance with an embodiment of the present system is a GUI for interaction within a network activity visualization to enable a user to navigate, view, analyze, create, and edit network activity, such as network traffic. Through use of the user interface in accordance with the present system, for example provided within the GUI, users are enabled to make use of network activity visualizations and to manipulate the activity, such as network traffic, in more flexible ways than previously possible.
The present system's user interface in one embodiment further provides a central window that enables the user to navigate, view, analyze, create, and edit network activity. In one embodiment, in enabling this functionality, the present system may provide one (1) or more, such as three (3) sets of interface portions, for example that may be implemented as plug-in program portions, referred to for simplicity as plug-ins, including arrangement/filtering, visualization, and manipulation. In one embodiment, each visualization may be implemented as separate programming portions. As may be readily appreciated, a plug-in may be a hardware and/or software module that adds a specific feature or service to a larger system, such as a network traffic collection system, network modeling system, etc. In accordance with an embodiment of the present system, one or more of the components of the present system may simply plug in to an existing system. One or more of the portions of the present system may enable developers to extend the behavior of the prior systems to accommodate new requirements. In an alternate embodiment, one or more of the portions of the present system may operate as stand-alone elements (e.g., tool(s)) importing and/or exporting activity data from any source to enable operation in accordance with the present system.
To facilitate the following discussion, for purposes of simplifying a description, the term “activity” as utilized herein is intended to include any activity type related to a network object, including traffic, delays, collisions, housekeeping processes, communication protocol, bits per second, packets per second and any other operations and/or characterizations of a network object. For example, the term activity may include network object characteristics such as source of traffic, destination of traffic, nodes, ports, etc. The activity may be provided from either or both of static (e.g., historical) and dynamic (e.g., live) data collected regarding the network activity. In accordance with the present system, the navigation pane may be utilized to view, organize, select, and edit network objects and activity characteristics related thereto, such as objects 144A, 114B, 114C that have associated activity characteristics.
In one embodiment, network objects may be represented as folders and may be displayed hierarchically in a tree-view. As may be readily appreciated, other network topologies may be similarly represented in the navigation pane 110. In one embodiment, the network objects are arranged in the navigation pane 110 (e.g., hierarchically) according to characteristics of activity related to the objects. For example, the network objects may be traffic elements. In accordance with this embodiment, the traffic elements may be arranged in the navigation pane 110 according to characteristics of the traffic. An “Arrange by:” menu item 112 may be utilized to determine criteria for the view provided in the navigation pane 110. For example, selection of the menu item 112 as shown in
Source—>Destination—>Protocol—>Port.
The network objects depicted (e.g., such as by folders) within the GUI in accordance with the present system may be depicted dynamically based on the selection criteria. As such, in this embodiment, the depicted objects are not static objects in that a change in selection criteria and/or a change in the underlying characteristics associated with the object, such as may be provided by a change in live characteristic data, may result in a change in the depicted object and/or activity characteristic(s). For example, a change in a Source->Destination relationship for network objects, from either of a static source that is updated or from live data, may result in a change in the visualization provided in the visualization pane 110.
A settings dialogue box, accessible via button 119, may be utilized for setting the network topology depiction, such as a default depiction (e.g., hierarchical network depiction), as well as other settings of the visualization as may be readily appreciated. Objects in the tree-view may be expanded and/or collapsed to reveal more or less details related to the network objects. For example, a check-box 116A may be utilized to indicate that further details related to the object are available within an expanded view. Further, the checkbox 116A may be utilized to provide the expanded view by manipulation of a cursor over the checkbox and performance of a selection activity, such as a left mouse-click as may be readily appreciated. Selection of a minus-box 116B may be utilized to collapse the expanded view. In one embodiment, to select a given network activity, the user may select one or more network objects that are related to the activity of interest, such as end-points of the activity.
To select a network object, the user may first set an “Arrange by:” menu item 112 to determine criteria for the view (e.g., such as a hierarchical view) provided in the navigation pane 110. In this way, together with respective checkboxes and minus-boxes, the user may set the view so that a desired object is visible in the tree-view. A find selection menu 118 provided in the navigation pane 110 may expand the hierarchical view to a suitable level to reveal a network object that is added to the find selection menu 118. In one embodiment, a network object that is added to the find selection menu 118, may also be automatically selected. When a desired network object is revealed and selected (e.g., by a single left mouse-click and/or by use of the find selection menu 118), the activity related to that network object may also be selected and be provided within one or more visualization panes 120, 130, 140. For example, end-to-end traffic may be provided on flows and baseline loads may be provided on network links, connections, and paths.
In one embodiment, if a menu element, such as menu element 254 is provided with a right arrow 256, a further menu may be provided by selection of the menu element 254. In the illustrative embodiment shown in
To edit network object activity in the visualization pane 210, the user may select the one or more objects and then choose a desired operation from the edit menu 250. Illustrative edit menu 250 options may include a “Set Traffic Start Times” edit option to specify a calendar start time for activity (e.g., traffic) on selected objects; a “Forecast Traffic” edit option to discern future activity by forecasting trends in current network activity and to, for example, append new traffic to the current traffic or selected network objects, or to overwrite current traffic; a “Roll Up Traffic Data” edit option to roll data up into groups of data, such as data buckets (e.g., equal sized buckets, buckets based on ranges of a given network characteristic, etc.) based on activity profile attributes (e.g., range of collection times, range of packet activity levels, range of number of packet collisions, etc.) of selected objects to reduce system resources required to run simulation studies which may also reduce data granularity available for visualization; a “Merge Flows” edit option to combine selected traffic flows that have common characteristics for multiple flows between the same node/destination to reduce the number of flow objects provided in a visualization; an “Add Volume to Traffic” to increase traffic on selected network objects by scaling (e.g., percent of current traffic) or addition (e.g., new traffic in bits per second); a “Delete Traffic” edit option to delete traffic on selected network objects such that if a traffic flow is selected, this operation may delete the network object entirely and if a link, connection, or path is selected, this operation may clear the traffic data on that network object; and an “Export Traffic to Files” edit option may be utilized to export traffic on selected network objects to external traffic files, including traffic on flows and traffic links, connections, and paths, which may be edited (if desired) and may be imported into other scenarios and/or systems. Further generalized or traffic specific edit operations may be enabled through the current GUI including operations for editing traffic through a number of pull-down menu operations for editing an individual network object in a traditional manner.
The navigation pane may also be utilized for visualization of other network activity, such as unmapped traffic.
One or more of the visualization panes may be provided with a pull-down menu, such as pull-down menus 422, 432, 442, with options for viewing different types of information related to one or more selected network objects. Illustrative examples of options that may be provided within one or more of the visualizations panes 422, 432, 442 may include a “Network Domain” option to provide a network topology visualization within a respective visualization pane; a “Network Showcase” option to provide a visualization for emphasizing particular areas of interest; a “Statistics Summary” option to provide summary statistics about the activity on one or more selected network objects; a “Total Bits/Packets Per Second” option to provide traffic volume on one or more selected objects; a “Top N Talkers by Volume” option to visualize source/sink nodes that send or receive the most traffic; and a “ToS/Port Breakdown” option which may provide a pie chart showing a breakdown of traffic by Type of Service (ToS) or port number. In accordance with an embodiment, further parameters may be set related to one or more of the options provided within the visualization panes 420, 430, 440. For example, to specify a number (“N”) of ports within a visualization with the “Top N Talkers by Volume” option selected, the user may set a parameter to specify the number “N”.
In one embodiment of the present system, by implementation of the navigation and visualization panes as separate programming portions (e.g., plug-ins), other suitable extensions and customizations may be provided including and beyond those shown by way of example herein. In one embodiment, an external file approach for related data may be provided to enable a user to customize the manipulation and/or visualization for a particular user, system, application, etc. For example, visualization and/or editing procedures may be registered by means of a file describing the title, function name and library of required and optional procedures. The required procedure(s) (e.g., an “arrange callback”) may be passed objects whose type is one of the types specified by an “object types” field. In this structured format, a location structure may be created which describes the location of the element in the hierarchy of the network elements provided in the navigation pane. Optional procedures may be utilized for initialization and/or destruction of any stateful data structures that assist the arrange callback in producing the visualization.
Visualization procedures may be described by a “visualize” element. Visualization procedures may be made available from the pull-down menus (e.g., pull-down menus 422, 432, 442) in the one or more visualization areas 420, 430, 440. A “title” attribute may specify text that appears in the pull-down menu item (e.g., “Statistics Summary”). A “library” attribute may specify a library where the procedures may be found. Visualization procedures may also have a “return” attribute to specify what type of data may be returned by the pull-down menu item. Illustrative possible return attributes may include “custom”, “graph”, and/or “table” attributes. A “custom” visualization attribute may also specify resources and/or controls to configure a corresponding visualization. Visualization procedures provided by the pull-down menu items may have an “update” function, which may also have an optional “type” attribute. In one embodiment, the type attribute may either be set to “manual” or “automatic”. For example, by default the update function may be set to “manual”. In a case wherein the update function is set to manual, then the visualization area for this function may be provided with an “Update” radio button that a user may press for the update function to be called, thereby updating the visualization provided in the visualization pane. However, in a case wherein the value of the type attribute is set to “automatic”, such as by user selection of an “automatic” option, then the update function may be called any time the selection set changes or may be called periodically.
In accordance with an embodiment, a manipulation and/or action procedure may be registered as a right-click menu item in the topology provided in the navigation pane. Right-click menu items may be specified by “action” elements. A “title” attribute may specify text that appears in the right-click menu. A “library” attribute may specify a library where procedures related to the menu item may be found. The function that is performed (e.g., called) when the menu item is selected may be given by a “select” element.
By enabling functionality as separate programming portions, the GUI provided in accordance with the present system may be customized, enhanced, etc., by a user to meet particular needs of the user. An implementation as plug-in programming portions enables the user to take an off-the-shelf implementation and customize the implementation as much or as little as desired. In addition, future needs may be readily met utilizing a prior implementation or separate program which is customized with additional features implemented as plug-ins to the prior implementation or separate program. Further, the present system may be distributed as having basic, intermediate and advanced feature sets at different price points wherein differences in the feature sets are implemented as plug-ins to a basic feature implementation.
A “Feature in Showcase” menu item may provide an interface and workflow for selecting a subset of network objects. This menu item/tool, may be provided to further aid the user in visualizing and manipulating activity of interest. In one embodiment, the menu item may be provided as a plug-in to enable a selection of individual network objects or groups of network objects provided in the visualization pane such that endpoints of the activity (e.g., source/destination network objects) may be featured in a special showcase window along with activity of the network objects. Copending U.S. patent application Ser. No. 11/503,555, entitled “VISUALIZING A COMPLEX NETWORK BASED ON A SET OF OBJECTS OF INTEREST”, incorporated herein by reference thereto as if set out in its entirety, describes an interface and workflow in accordance with this embodiment of the present system. In a further embodiment, simulation/analysis operations may be provided by the menu-item to compute end-to-end routes or paths of activity within the network and to show the activity endpoints alone or together with intermediate nodes along the activity path.
An arrange-by menu-item (e.g., see
In a further embodiment in accordance with the present system, a “time window” menu item may incorporate a graphical control element for the user to specify a starting and ending time range. By specifying the time window, the user may effectively perform a global filtering operation such that the set of activity available for visualization and/or manipulation provided in the navigation and/or visualization panes is filtered to only the activity occurring (e.g., having measured volume levels) within the specified time range. In this way, traffic for which no data is recorded for the user-specified time range may be filtered out so that it no longer appears in the visualization pane and therefore is not selectable for visualization and/or modification. Furthermore, visualizations that report on activity volumes/levels may be limited to operate on only the activity volumes recorded for the user-specified time period. For example, for a visualization showing aggregate bits per second over time for a selected set of activity, filtering based on a time interval may cause a visualization (e.g., a graph) to only display the activity of the selected network objects, services, etc., for the time range selected, thereby omitting any display of activity outside of the provided time window.
In an embodiment in accordance with the present system, network performance data, such as Quality of Service (QoS), etc., may be incorporated into a visualization to incorporate performance data that is relevant to activity demands in one or more of the provided visualizations. In one embodiment, the performance data may be collected directly from a network. For example, polling using Simple Interface Management Protocol (SNMP) may be utilized for router interface Management Interface Base (MIB) data (e.g., utilization, loss, errors, etc.) along a path the activity takes. Further, active performance measurement data may be associated with current traffic demands. For example, traffic visualized within a visualization pane may represent aggregate pair traffic, such as within a given city, network portion, etc., and a data insertion device, such as a Brix probe, may be used to send synthetic packets to measure delay, jitter, loss, Mean Opinion Score (MOS), etc., associated with the traffic. In an alternate embodiment, the data may be generated by modeling the network and simulating aspects of performance.
In either case, whether utilizing measured or simulated performance data, a visualization provided in an embodiment in accordance with the present system may associate individual network objects and characteristics, such as traffic objects (e.g., flows), with its relevant performance data. This visualization enables activities, such as network traffic, to be grouped by performance categories (e.g., group by traffic by differing ranges of performance, group all demands that experienced a performance problem on a particular network device or interface, etc.).
In accordance with a further embodiment, the present system may represent activity data that has been read or imported from one or more of static data sources and live data sources, such as a live data feed. In a further embodiment, the data source may update one or more portions of the data utilized for providing the present visualizations, periodically in any defined period (e.g., every 60 seconds, every 5 minutes, every 15 minutes, etc.). These updates may be provided as a portion of an activity of a system having other tasks, such as tasks not related to visualizations and/or manipulations in accordance with the present or may represent a task of a dedicated system. The updates may be requested by a portion of the present system, such as through a plug-in module, or may be forwarded as a result of a task relegated to a further system.
In accordance with the present system, upon receiving the updated set of activity information or some time thereafter, the present system may recompute statistics, arrange-by membership, and/or update visualizations or portions thereof. Accordingly, a dynamically updating interface may be provided, such as by a plug-in, as new activity data arrives. An aging mechanism may be employed to roll off or age out (e.g., expunge, decrease relevance, filter) older activity data. For example, activity data may be filtered to avoid having an effect on a presentation of data to maintain activity data memory usage at a substantially constant level. Other activity data may be expunged, filtered, etc., based on a user and/or system determinable event, such as based on a determination that the activity data represents an infrequent event and therefore may be of little interest for analysis. For example, activity data related to an infrequent application deployment may be of little interest when performing analysis and/or manipulations related to day-to-day network activities. In another embodiment, all activity data related to other than the user and/or system determinable event (e.g., the infrequent event) may be expunged because it is of little interest for analysis of network activity related to the infrequent event. For example, activity data related to the infrequent application deployment may be of interest when performing analysis and/or manipulations related to the infrequent application deployment.
In one embodiment, the present system may provide a capability to limit (e.g., filter) activity related to a given range of time (e.g., minutes, hours, etc.) during which the activity data should apply (e.g. only forecast based on business hour network activities). The present system may also incorporate and/or provide periodic (e.g. seasonal) analysis for focused visualizations including forecasts.
The present system may provide additional visualization and/or manipulation options, such as a smart aggregation by port, organize traffic by known ports, etc. A manipulation in accordance with the present system may enable reconciling loads and flow data through network routing manipulations. A de-duplicating of flow data (activity) may be provided based on routing knowledge. In accordance with an embodiment of the present system, network activity may be visualized and/or manipulated by dragging and dropping a set of elements from one folder to another. In accordance with a further embodiment, batch or macro operations for performing an action on each of the selected folders may be visualized and/or manipulated instead of an aggregate of all the folders provided in a visualization.
In one embodiment, the visualizations and/or manipulations provided in accordance with the present system may be available as part of a modeling environment that includes a routing engine. Accordingly, the present system may utilize network activity data related to a hop-by-hop route of each network object (e.g., such as traffic flow) or virtual network objects (e.g., connections) such as provided by Multi-protocol Label Switching (MPLS), Label Switched Paths (LSPs), Asynchronous Transfer Mode (ATM), Permanent Virtual Circuit (PVC), etc. Accordingly, it may be natural for users of the present system to address questions and/or provide manipulations regarding individual activities, such as traffic flows, that may embed routing computations. One workflow of this type that may be enabled by the present system is a reasoning provided from a known network issue to identify traffic demands that are affected by it. For example, the present system may provide a visualization of network problems of various types, such as over-utilized links, excessive loss on a link, etc.
The present system may group flows, activities, etc., affected by these problems, characterize the nature of those flows (e.g., which ones are sensitive to the problem and which ones may be more tolerant of the problem), and/or provide some indication of a magnitude of the problem. Conversely, flows, activities, etc., not affected by these problems may be visualized. For example, in a case wherein a traffic demand is known to have a performance problem, such as determined from performance measurements taken directly from a network, or as determined by a user of the network such as provided in a trouble report, the present system may be utilized to enable a visualized walk of the route of the traffic flow (computed by the routing model). For example, performance data already collected along that path may be examined (e.g., router interface MIB data) or selectively turned on in an attempt to diagnose where the activity (e.g., traffic flow) is experiencing a problem.
In accordance with an embodiment, additional network objects, traffic elements, activities, flows, etc., may be added to enable visualization and/or manipulation. For example, flows may be imported and/or merged with existing traffic elements visualized by the present system. These additional elements may be automatically or manually added to the organization of traffic in an arrange-by navigation pane. In this way, by selecting the additional traffic, the visualizations may update to take this new additional traffic into account for displaying statistics, graphs, and other such visualizations.
Activity data visualized and/or manipulated in accordance with the present system may be exported from the present system to a separate system for further visualizations and/or manipulations. In this way, the present system may create a data file that is exported to the separate system for operations in accordance with the separate system, such as for analysis by the separate system. In another embodiment, manipulations to network objects and/or activity characteristics associated with the network objects may be exported to a system that controls management and/or manipulation of the network such that manipulations performed within the GUI of the present system, may be implemented. In this way, data, manipulations of data, etc., may be exported to or imported from the separate system.
The methods of the present system are particularly suited to be carried out by a computer software program, such program containing modules and/or plug-ins corresponding to one or more of the individual steps or acts described and/or envisioned by the present system. Such program and/or program portions may of course be embodied in a computer-readable medium, such as an integrated chip, a peripheral device or memory, such as the memory 720 and/or other memory coupled to the processor 710.
The computer-readable medium and/or memory 720 may be any recordable medium (e.g., RAM, ROM, removable memory, CD-ROM, hard drives, DVD, floppy disks or memory cards) or may be a transmission medium (e.g., a network comprising fiber-optics, the world-wide web, cables, or a wireless channel using time-division multiple access, code-division multiple access, or other radio-frequency channel). Any medium known or developed that may store and/or transmit information suitable for use with a computer system may be used as the computer-readable medium and/or memory 720.
Additional memories may also be used. The computer-readable medium, the memory 720, and/or any other memories may be long-term, short-term, or a combination of long-term and short-term memories. These memories configure processor 710 to implement the GUIs, methods, operational acts, and functions disclosed herein. The memories may be distributed or local and the processor 710, where additional processors may be provided, may also be distributed or may be singular. The memories may be implemented as electrical, magnetic or optical memory, or any combination of these or other types of storage devices. Moreover, the term “memory” should be construed broadly enough to encompass any information able to be read from or written to an address in the addressable space accessible by a processor. With this definition, information available on a network is still within the memory 720, for instance, because the processor 710 may retrieve the information from the network for operation in accordance with the present system.
The processor 710 is capable of providing control signals and/or performing operations in response to input signals from the user input device 770 and executing instructions stored in the memory 720. The processor 710 may be an application-specific and/or general-use integrated circuit(s). Further, the processor 710 may be a dedicated processor for performing in accordance with the present system and/or may be a general-purpose processor wherein only one of many functions operates for performing in accordance with the present system. The processor 710 may operate utilizing a program portion, multiple program segments, plug-ins, etc. and/or may be a hardware device utilizing a dedicated or multi-purpose integrated circuit.
Of course, it is to be appreciated that any one of the above embodiments or processes may be combined with one or more other embodiments or processes or be separated in accordance with the present system. As should be clear, the present system enables a visualization and/or manipulation of network activity beyond that provided by prior systems.
Finally, the above-discussion is intended to be merely illustrative of the present system and should not be construed as limiting the appended claims to any particular embodiment or group of embodiments. Thus, while the present system has been described with reference to exemplary embodiments, it should also be appreciated that numerous modifications and alternative embodiments may be devised by those having ordinary skill in the art without departing from the broader and intended spirit and scope of the present system as set forth in the claims that follow. For example, while modifications to network operating characteristics are described in terms of actual implementations of the modifications on an operating network, these modifications may similarly be made within a simulation environment wherein the modifications are simulated and simulation data is acquired for accessing an affect of the modifications. Accordingly, these modifications and others are intended to be covered within the scope of the present system.
In addition, the section headings included herein are intended to facilitate a review but are not intended to limit the scope of the present system. Accordingly, the specification and drawings are to be regarded in an illustrative manner and are not intended to limit the scope of the appended claims.
In interpreting the appended claims, it should be understood that:
a) the word “comprising” does not exclude the presence of other elements or acts than those listed in a given claim;
b) the word “a” or “an” preceding an element does not exclude the presence of a plurality of such elements;
c) any reference signs in the claims do not limit their scope;
d) several “means” may be represented by the same item or hardware or software implemented structure or function;
e) any of the disclosed elements may be comprised of hardware portions (e.g., including discrete and integrated electronic circuitry), software portions (e.g., computer programming), and any combination thereof,
f) hardware portions may be comprised of one or both of analog and digital portions;
g) any of the disclosed devices or portions thereof may be combined together or separated into further portions unless specifically stated otherwise;
h) no specific sequence of acts or steps is intended to be required unless specifically indicated; and
i) the term “plurality of” an element includes two or more of the claimed element, and does not imply any particular range of number of elements; that is, a plurality of elements may be as few as two elements, and may include an immeasurable number of elements.
This application claims the benefit of U.S. Provisional Patent Application No. 60/821,020, filed Aug. 1, 2006.
Number | Date | Country | |
---|---|---|---|
60821020 | Aug 2006 | US | |
60821018 | Aug 2006 | US |